题目

https://leetcode.com/problems/burst-balloons/

题解

好久不 DP 了,DP 一下吧,结果被坑了很久,看了答案。

递归的时候,我知道分成L,R两边,但是一直按着先删M,再删左右想的,结果删除顺序有依赖。

看了答案之后发现,要先删左右,最后删M。因为:

  • 如果最后删M,能确定M的左边一定是L-1,右边一定是R+1
  • 如果先删M,就不能确定M-1的右边是什么,也不能确定M+1的左边是什么
class Solution {public int maxCoins(int[] nums) {int[] arr = new int[nums.length + 2];arr[0] = 1;arr[arr.length - 1] = 1;System.arraycopy(nums, 0, arr, 1, nums.length);int[][] dp = new int[nums.length + 2][nums.length + 2];for (int[] d : dp) {Arrays.fill(d, Integer.MIN_VALUE);}return process(arr, 1, arr.length - 2, dp);}// 完整的从L到R(而且L-1,R+1都未被删)能得到的最大结果public int process(int[] arr, int L, int R, int[][] dp) {if (L > R) return 0;else if (dp[L][R] != Integer.MIN_VALUE) {return dp[L][R];} else if (L == R) {dp[L][R] = arr[L - 1] * arr[L] * arr[L + 1];return dp[L][R];}int result = 0;for (int M = L; M <= R; M++) { // 对于任意一个M,此时M的左右都是完整的。删除顺序是:先删光M的左边,然后删光M的右边,最后删Mresult = Math.max(result, arr[L - 1] * arr[M] * arr[R + 1] + process(arr, L, M - 1, dp) + process(arr, M + 1, R, dp));}dp[L][R] = result;return result;}
}

leetcode 312. Burst Balloons | 312. 戳气球(暴力递归->DP)相关推荐

  1. LeetCode 312. Burst Balloons(戳气球)

    原题网址:https://leetcode.com/problems/burst-balloons/ Given n balloons, indexed from 0 to n-1. Each bal ...

  2. 312. Burst Balloons 戳气球

    Title 有 n 个气球,编号为0 到 n-1,每个气球上都标有一个数字,这些数字存在数组 nums 中. 现在要求你戳破所有的气球.如果你戳破气球 i ,就可以获得 nums[left] * nu ...

  3. 312. 戳气球(区间dp)

    链接:https://leetcode-cn.com/problems/burst-balloons/ 首先这个长度为500的范围可以猜测出是O(n^3)区间dp 这里主要讲述为什么状态定义要定义成开 ...

  4. LeetCode 312. Burst Balloons

    一看就是DP题,但是递推公式比较难想.为了简化问题,给 nums 开始和最后都加上1. 记 dp[i][j] 表示 nums[i~j] 能得到的最大coin. k 表示保留着的气球, dp[i][j] ...

  5. 【Leetcode】312. Burst Balloons

    第一种思路可以采用backtracking.把一个list传递下去,每一步可以选择任意一个删除,然后再递归处理下一个,比较简单. public int maxCoins1(int[] nums) {i ...

  6. 312. Burst Balloons

    题目: Given n balloons, indexed from 0 to n-1. Each balloon is painted with a number on it represented ...

  7. LeetCode 514. 自由之路(记忆化递归 / DP)

    文章目录 1. 题目 2. 解题 1. 题目 电子游戏"辐射4"中,任务"通向自由"要求玩家到达名为"Freedom Trail Ring" ...

  8. leetcode 790. Domino and Tromino Tiling | 790. 多米诺和托米诺平铺(暴力递归->DP)

    题目 https://leetcode.com/problems/domino-and-tromino-tiling/ 题解 比较像剑指 offer 里的一道矩形填充题,一看就是个 dp,见草稿: 经 ...

  9. leetcode 712. Minimum ASCII Delete Sum for Two Strings | 712. 两个字符串的最小ASCII删除和(暴力递归->傻缓存->DP)

    题目 https://leetcode.com/problems/minimum-ascii-delete-sum-for-two-strings/ 题解 经典的 暴力递归 -> 傻缓存 -&g ...

最新文章

  1. OPenfire简介
  2. 041_Unicode对照表七
  3. documentElement vs body区别
  4. PHP 运动会,运动会成绩管理系统
  5. Active Directory相关博客
  6. python京东注册账号_Python爬虫模拟登录京东获取个人信息
  7. 序列化 - 实现ISerializable
  8. hiveserver2 mysql_HiveServer2的配置使用
  9. 十二、实战底部(二)
  10. 每日命令之vim简单使用
  11. socket.io实现客户端和服务端的双向通信
  12. MKV(Matroska)常见问题浅析
  13. 自动配置和 thymeleaf模板引擎
  14. c++求两条直线的交点
  15. 陈 好 性 感 写 真 ,难得一见哦[贴图]
  16. laravel5.4新特性
  17. 想做网上线上引流怎么做?如何通过网络获取流量?
  18. 《STL源码剖析》总结
  19. PLP: 4.2/4.3 Attribute Gramma阅读笔记3
  20. pthread_t总结

热门文章

  1. CodeForces - 1312E Array Shrinking(区间dp)
  2. HDU - 5658 CA Loves Palindromic(回文自动机/哈希+树状数组)
  3. 多个客户端抢夺命名管道_使用Kafka构建数据管道
  4. 机器学习-机器学习简介
  5. Spring MVC 入门--Hello World
  6. 28.特性trait.rs
  7. H.264码流结构解析
  8. COM编程之一 组件
  9. 如何用ARP欺骗来嗅探主机流量
  10. VC程序初始化隐藏窗体