糖逗 发表于 2021-4-9 18:01:55

C++刷leetcode(740. 删除与获得点数***)【动态规划】【问题转化】

题目描述:
给定一个整数数组 nums ,你可以对它进行一些操作。

每次操作中,选择任意一个 nums ,删除它并获得 nums 的点数。之后,你必须删除每个等于 nums - 1 或 nums + 1 的元素。

开始你拥有 0 个点数。返回你能通过这些操作获得的最大点数。

示例 1:

输入: nums =
输出: 6
解释:
删除 4 来获得 4 个点数,因此 3 也被删除。
之后,删除 2 来获得 2 个点数。总共获得 6 个点数。
示例 2:

输入: nums =
输出: 9
解释:
删除 3 来获得 3 个点数,接着要删除两个 2 和 4 。
之后,再次删除 3 获得 3 个点数,再次删除 3 获得 3 个点数。
总共获得 9 个点数。
注意:

nums的长度最大为20000。
每个整数nums的大小都在范围内。

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/delete-and-earn
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

class Solution {
public:
    int deleteAndEarn(vector<int>& nums) {
      //将问题变型(打家劫舍)
      int max_num = *max_element(nums.begin(), nums.end());
      vector<int>store(max_num+1, 0);
      for(auto num: nums){
            store++;
      }
      //动态规划
      int len = store.size();
      vector<int>dp(len, 0);
      dp = store;
      for(int i = 2; i < len; i++){
            dp = max(dp, dp + store * i);
      }
      return dp;
    }
};

糖逗 发表于 2021-4-9 18:02:31

{:10_329:}
页: [1]
查看完整版本: C++刷leetcode(740. 删除与获得点数***)【动态规划】【问题转化】