Burst Balloons (Medium)

这题没有做出来. 自己的思路停留在暴力的解法, 时间复杂度很高:

  1. 初始化maxCount = 0.
  2. 对于当前长度为k的数组nums, 从0k - 1逐个选取第i个气球扎破
    1. 计算扎破气球得到的金币数, count = nums[i - 1] * nums[i] * nums[i + 1].
    2. nums中删掉nums[i].
    3. 查询m[nums]是否存在, 不存在则递归调用maxCoins(nums)并插入m[nums].
    4. count += m[nums]后就是本轮的最优解, 若count > maxCount则更新maxCount.
    5. 恢复nums[i]回到nums中.
  3. 返回maxCount.
class Solution {
private:
map<vector<int>, int> m;
public:
int maxCoins(vector<int>& nums) {
int len = nums.size();
if (len <= 0) return 0;
if (len == 1) return nums[0];
int maxCount = 0;
for (int i = 0; i < len; ++i) {
int val = nums[i];
int count = nums[i];
if (i - 1 >= 0) {
count *= nums[i - 1];
}
if (i + 1 < len) {
count *= nums[i + 1];
}
nums.erase(nums.begin() + i);
auto it = m.find(nums);
if (it == m.end()) {
count += (m[nums] = maxCoins(nums));
} else {
count += it->second;
}
maxCount = max(maxCount, count);
nums.insert(nums.begin() + i, val);
}
return maxCount;
}
};

这个算法如果不加memo, 在第i次选择时有n - i个选择 (i = 0 ~ n-1), 所以一共有n!次选择, 每次选择都要进行O(n)时间复杂度的删气球和回填气球的操作查找vector的时间复杂度是多少?, 故时间复杂度O(n*n!), n层递归故空间复杂度O(n).

如上加了memo之后, 对于每种输入情况只计算一次, 对于k个气球, 有C(n, k)中情况 (k = 1~n), 一共是2^n种情况, 同上要考虑增删气球的时间复杂度, 所以时间复杂度最好也是O(n*2^n). 这2^n种情况都要保存在memo中, 每种输入的平均长度是O(n)级别的, 因此空间复杂度是O(n*2^n).

总之, TLE.


看了Share some analysis and explanations之后写下了下面的算法.

class Solution {
private:
map<pair<int, int>, int> m;
int maxCoins(vector<int> &nums, int left, int right, int lv, int rv) {
if (left > right) return 0;
if (left == right) return nums[left] * lv * rv;
auto coor = make_pair(left, right);
auto it = m.find(coor);
if (it != m.end()) {
return it->second;
}
int maxCount = 0;
for (int i = left; i <= right; ++i) {
int count = nums[i] * lv * rv
+ maxCoins(nums, left, i - 1, lv, nums[i])
+ maxCoins(nums, i + 1, right, nums[i], rv);
maxCount = max(maxCount, count);
}
m[coor] = maxCount;
return maxCount;
}
public:
int maxCoins(vector<int>& nums) {
int len = nums.size();
if (len <= 0) return 0;
return maxCoins(nums, 0, len - 1, 1, 1);
}
};
// Runtime: 1428ms

时间复杂度O(n^3). 起止点共有C(n, 2)个组合, 是O(n^2)级别的. 对于每个组合要遍历一遍, 找最大. 所以整体是O(n^3).

空间复杂度O(n^2).

小优化:

  1. 删掉0. (Runtime: 1300ms).
  2. 改用数组做map (Runtime: 36ms). 没想到数组比map好用这么多, 为什么?
class Solution {
private:
int maxCoins(vector<int> &nums, int left, int right, int lv, int rv, int* memo, int n) {
if (left > right) return 0;
if (left == right) return nums[left] * lv * rv;
if (memo[left * n + right] != 0) return memo[left * n + right];
int maxCount = 0;
for (int i = left; i <= right; ++i) {
int count = nums[i] * lv * rv
+ maxCoins(nums, left, i - 1, lv, nums[i], memo, n)
+ maxCoins(nums, i + 1, right, nums[i], rv, memo, n);
maxCount = max(maxCount, count);
}
memo[left * n + right] = maxCount;
return maxCount;
}
public:
int maxCoins(vector<int>& nums) {
int len = nums.size();
if (len <= 0) return 0;
int n = 0;
for (int x : nums) if (x > 0) nums[n++] = x;
int memo[n][n] = {};
return maxCoins(nums, 0, n - 1, 1, 1, (int*)memo, n);
}
};

标准答案:

class Solution {
public:
int maxCoins(vector<int>& iNums) {
int nums[iNums.size() + 2];
int n = 1;
for (int x : iNums) if (x > 0) nums[n++] = x;
nums[0] = nums[n++] = 1; int dp[n][n] = {};
for (int k = 2; k <= n; ++k) {
for (int L = 0; L <= n - k; ++L) {
int R = L + k;
for (int i = L + 1; i < R; ++i) {
dp[L][R] = max(dp[L][R], nums[L] * nums[i] * nums[R] + dp[L][i] + dp[i][R]);
}
}
}
return dp[0][n - 1];
}
};
// Runtime: 12ms

其中dp[i][j]表示第i个气球到第j个气球能获取的最大金币数 (i最小为-1, j最大为n).

[LeetCode] Burst Balloons (Medium)的更多相关文章

  1. [LeetCode] Burst Balloons 打气球游戏

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

  2. LeetCode Burst Balloons

    原题链接在这里:https://leetcode.com/problems/burst-balloons/ 题目: Given n balloons, indexed from 0 to n-1. E ...

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

    参考:LeetCode 312. Burst Balloons(戳气球) java代码如下 class Solution { //参考:https://blog.csdn.net/jmspan/art ...

  4. 【LeetCode】452. Minimum Number of Arrows to Burst Balloons 解题报告(Python)

    [LeetCode]452. Minimum Number of Arrows to Burst Balloons 解题报告(Python) 标签(空格分隔): LeetCode 题目地址:https ...

  5. LN : leetcode 312 Burst Balloons

    lc 312 Burst Balloons 312 Burst Balloons Given n balloons, indexed from 0 to n-1. Each balloon is pa ...

  6. 贪心:leetcode 870. Advantage Shuffle、134. Gas Station、452. Minimum Number of Arrows to Burst Balloons、316. Remove Duplicate Letters

    870. Advantage Shuffle 思路:A数组的最大值大于B的最大值,就拿这个A跟B比较:如果不大于,就拿最小值跟B比较 A可以改变顺序,但B的顺序不能改变,只能通过容器来获得由大到小的顺 ...

  7. 动态规划-Burst Balloons

    Burst Balloons Given n balloons, indexed from 0 to n-1. Each balloon is painted with a number on it ...

  8. [LeetCode] Minimum Number of Arrows to Burst Balloons 最少数量的箭引爆气球

    There are a number of spherical balloons spread in two-dimensional space. For each balloon, provided ...

  9. [LeetCode] 312. Burst Balloons 打气球游戏

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

随机推荐

  1. SQL Server delete、truncate、drop

    在T-SQL中这三个命令符,相信很多朋友都不会陌生的,我自己在工作也会常常使用到它们,虽然我们清除的知道用这三个命令符可以达到怎样的预期效果. 但是却很少深入的去了解它们,知道它们有什么区别,又各有什 ...

  2. 20160322 javaweb 学习笔记--response 重定向

    //一般方法 response.setStatus(302); response.setHeader("Location", "/20160314/index.jsp&q ...

  3. Android开发之Handler

    我们都知道应用程序开启后,安卓会开启一个主线程(UI线程),主线程管理UI控件,进行事件分发.那为什么会出现Handler呢? 例如你要是点击一个 Button ,Android会分发事件到Butto ...

  4. [转]SQL语句:Group By总结

    1. Group By 语句简介: Group By语句从英文的字面意义上理解就是“根据(by)一定的规则进行分组(Group)”.它的作用是通过一定的规则将一个数据集划分成若干个小的区域,然后针对若 ...

  5. cocos2d-x使用DragonBones动画

    前言 在网上查找关于DragonBones在cocos2d-x的使用教程,找了大半天也没有找到一个有用的.在自己摸索了一段时间终于摸索了出来,在这里记下分享给大家. 下载DragonBones 我这里 ...

  6. Demo_张仕传_结构体考试-modify

    /* 题目: //声明一个结构体类型 struct _AdvTeacher { char *name; char *tile; int age; char *addr; char *p1; //系统预 ...

  7. yii2单个视图加载jss,css

    1,定义资源:首先在AppAsset.php里面定义2个方法, //按需加载css public static function addCss($view, $cssfile) { $view-> ...

  8. 跨域、sql注入、xss攻击

    这几天遇到这三个问题,现在简单的记录下来. 1.跨域 如我服务器的域名是www.test1.com,我在另一个服务器www.test2.com通过ajax访问www.test1.com的数据时,就引起 ...

  9. bss段为什么需要初始化?

    我们都知道bss段需要初始化,但是这是为什么呢? 通过浏览资料,我们都会发现,bss段是不会出现在程序下载文件(*.bin *.hex)中的,因为全都是0.如果把它们出现在程序下载文件中,会增加程序下 ...

  10. load-store/register-memory/register-plus-memory比较

    在理解ARM的load-store架构时,我在百度上搜索了很长时间,但是始终找不到一篇像样的中文文章.最后,在用谷歌搜索的英文网站上终于找到了一些蛛丝马迹.让我们先看一下一篇英文资料. Process ...