LeetCode | 312. Burst Balloons 树状DP

Given n balloons, indexed from 0 to n-1. Eachballoon is painted with a number on it represented by array nums. You are asked to burst all theballoons. If the you burst balloon i you will get nums[left] * nums[i] * nums[right] coins. Here left and right areadjacent indices of i. After theburst, the left and right then becomes adjacent.

Findthe maximum coins you can collect by bursting the balloons wisely.

Note: 
(1) You may imagine
 nums[-1] = nums[n] = 1. They are not real therefore you can not burst them.
(2) 0 ≤
 n ≤ 500, 0 ≤ nums[i] ≤ 100

Example:

Given [3, 1, 5, 8]

Return 167

    nums = [3,1,5,8]--> [3,5,8] -->   [3,8]   --> [8]  --> []

   coins =  3*1*5     +  3*5*8    + 1*3*8      + 1*8*1   = 167

Credits:
Special thanks to
 @dietpepsi for adding this problem and creating all test cases.

这是一题典型的二分dp题目,以后在做题的时候一定要记住,二分dp也可以称为树状dp,特点是假设最后一步取值i,那么0~I,和i+1~n也具有最优子结构,确实很抽象,不过想几遍就能明白,

这一题还可以进一步优化,当取for循环里面最大的一个tmp,然后将这个值赋给指定数组位置num[i]的时候,可以优化成num[i]=max(num[i],tmp),这样可以减少题目的步骤!

class Solution {

public:

intmaxCoins(vector<int>& nums) {

      int n = nums.size(); intend,tmp1,tmp2,score,tmp;

      vector<vector<int>> dp(n+2,vector<int>(n+2, 0));

      for(int l=1;l<=n;l++)

            for (int i = 0; i <= n - l; i++)

            {

                  score = -1;

                  end = i + l - 1;

                  for (int h = i; h <= end;h++)

                  {

                       tmp1 = i - 1 >= 0 ?nums[i - 1] : 1;

                       tmp2= end + 1 >= n ? 1: nums[end+1];

                       tmp = tmp1*tmp2*nums[h] +dp[i+1][h] + dp[h + 2][end+1];

                       score = max(score, tmp);

                  }

                  dp[i + 1][end + 1] = score;

            }

      return dp[1][n];

}

};

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值