【学会动态规划】删除并获得点数(13)

这篇具有很好参考价值的文章主要介绍了【学会动态规划】删除并获得点数(13)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

目录

动态规划怎么学?

1. 题目解析

2. 算法原理

1. 状态表示

2. 状态转移方程

3. 初始化

4. 填表顺序

5. 返回值

3. 代码编写

写在最后:


动态规划怎么学?

学习一个算法没有捷径,更何况是学习动态规划,

跟我一起刷动态规划算法题,一起学会动态规划!

1. 题目解析

题目链接:740. 删除并获得点数 - 力扣(Leetcode)

【学会动态规划】删除并获得点数(13),学会动态规划,动态规划,算法,c++,学习

这道题比较抽象,我就拿他给的样例举例子吧,

【学会动态规划】删除并获得点数(13),学会动态规划,动态规划,算法,c++,学习

如果选择 3,就需要把 4 和 2 都删除,那么点数就是 3

如果选择 2,就需要把 1 和 3 都删除,那么继续选择 4 ,需要把 3 和 5 删除,

最后点数加在一起就是 2 + 4 = 6,最大点数是 6 所以返回 6。

同理,第二个示例:

【学会动态规划】删除并获得点数(13),学会动态规划,动态规划,算法,c++,学习

还是两种情况,选 2,4,或者选 3。 

注意是选择一个数之后,这数 + 1 和 - 1 就会被删除。

实际上,这道题如果直接做的话并不好做,

我们可以对他进行一些预处理的操作,来转化成我们熟悉的问题:

这里我还是用题目给的示例演示:

【学会动态规划】删除并获得点数(13),学会动态规划,动态规划,算法,c++,学习

我们通过下标对应点数的形式,转化出一个新数组:

【学会动态规划】删除并获得点数(13),学会动态规划,动态规划,算法,c++,学习

 比如说,原数组从 2 开始,那点数数组下标为 2 的位置就是点数 2 + 2 = 4,

然后下标为 3 的位置点数就是 3 + 3 = 6,下标为 4 的位置点数就是 4 。

这样做,就能把这个问题转化成打家劫舍的问题了:相邻的下标不能同时选择。

2. 算法原理

1. 状态表示

然后这个问题就有两种情况,:

f [ i ] 表示选到 i 位置的时候,nums[ i ] 选,此时能得到的最大点数

g [ i ] 表示选到 i 位置的时候,nums[ i ] 不选,此时能得到的最大点数 

2. 状态转移方程

所以状态转移方程也有两个,

选 i 位置,就是nums[ i ] + 不选 i - 1 位置的情况:f [ i ]  = g[ i - 1 ] + nums[ i ]

g[ i ] = max( f [ i - 1 ],g[ i - 1 ] )

3. 初始化

f [ 0 ] = nums[  0 ],g[ 0 ] = 0。

4. 填表顺序

从左往右

5. 返回值

max( f [ n - 1 ],g[ n - 1 ] )

3. 代码编写

class Solution {
public:
    int deleteAndEarn(vector<int>& nums) {
        sort(nums.begin(), nums.end());
        vector<int> dp(nums[nums.size() - 1] + 1);
        for(auto e : nums) dp[e] += e;
        int n = dp.size();
        vector<int> f(n);
        auto g = f;
        f[0] = dp[0];
        for(int i = 1; i < n; i++) {
            f[i] = g[i - 1] + dp[i];
            g[i] = max(f[i - 1], g[i - 1]);
        }
        return max(f[n - 1], g[n - 1]);
    }
};

写在最后:

以上就是本篇文章的内容了,感谢你的阅读。

如果感到有所收获的话可以给博主点一个哦。

如果文章内容有遗漏或者错误的地方欢迎私信博主或者在评论区指出~文章来源地址https://www.toymoban.com/news/detail-609310.html

到了这里,关于【学会动态规划】删除并获得点数(13)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 60题学会动态规划系列:动态规划算法第三讲

    简单多状态问题 文章目录 一.按摩师 二.打家劫舍系列 三.删除并获得点数 四.粉刷房子 力扣链接:力扣 一个有名的按摩师会收到源源不断的预约请求,每个预约都可以选择接或不接。在每次预约服务之间要有休息时间,因此她不能接受相邻的预约。给定一个预约请求序列,

    2024年02月08日
    浏览(48)
  • 60题学会动态规划系列:动态规划算法第二讲

    都是路径问题~ 文章目录 1.不同路径 2.不同路径II 3.礼物的最大价值 4.下降路径最小和 5.最小路径和 力扣链接:力扣 一个机器人位于一个  m x n   网格的左上角 (起始点在下图中标记为 “Start” )。 机器人每次只能向下或者向右移动一步。机器人试图达到网格的右下角(在

    2024年02月07日
    浏览(59)
  • 60题学会动态规划系列:动态规划算法第四讲

    买卖股票相关的动态规划题目 文章目录 1. 买卖股票的最佳时机含冷冻期 2. 买卖股票的最佳时期含⼿续费 3. 买卖股票的最佳时机III 4. 买卖股票的最佳时机IV 力扣链接:力扣 给定一个整数数组 prices ,其中第    prices[i]  表示第  i  天的股票价格 。​ 设计一个算法计算出最

    2024年02月13日
    浏览(34)
  • 60题学会动态规划系列:动态规划算法第五讲

    子数组系列题目 文章目录 1.最大子数组和 2.环形子数组的最大和 3.乘积最大数组 4.乘积为正数的最长子数组长度 5.等差数列划分 6.最长湍流子数组 7.单词拆分 8.环绕字符串中唯一的子字符串 力扣链接:力扣 给你一个整数数组  nums  ,请你找出一个具有最大和的连续子数组(

    2024年02月15日
    浏览(55)
  • 60题学会动态规划系列:动态规划算法第一讲

    坚持就是胜利 - -  文章目录 1.第N个泰波那切数 2.三步问题 3.使用最小花费爬楼梯 4.解码方法 力扣链接:力扣 泰波那契序列 Tn 定义如下:  T0 = 0, T1 = 1, T2 = 1, 且在 n = 0 的条件下 Tn+3 = Tn + Tn+1 + Tn+2 给你整数  n ,请返回第 n 个泰波那契数 Tn 的值。  首先我们分析一下

    2024年02月06日
    浏览(44)
  • day52 算法训练|动态规划part13

    参考:代码随想录 1. dp[i]的定义 本题中,正确定义dp数组的含义十分重要。 dp[i]表示i之前包括i的以nums[i]结尾的最长递增子序列的长度 为什么一定表示 “以nums[i]结尾的最长递增子序” ,因为我们在 做 递增比较的时候, 如果比较 nums[j] 和 nums[i] 的大小,那么两个递增子序列

    2024年01月15日
    浏览(39)
  • 【算法】【Python3、动态规划、贪心、二分查找】力扣1671. 得到山形数组的最少删除次数

    1671. 得到山形数组的最少删除次数 给定一个整数数组 nums ,我们定义该数组为山形数组当且仅当: nums 的长度至少为 3。 存在一个下标 i 满足 0 i len(nums) - 1 且: nums[0] nums[1] ... nums[i - 1] nums[i] nums[i] nums[i + 1] ... nums[len(nums) - 1] 现在,给定整数数组 nums ,我们的目标是将其变为

    2024年01月18日
    浏览(52)
  • 【算法每日一练]-动态规划(保姆级教程 篇13)POJ2686马车旅行 #POJ3254 玉米田 #POJ1185:炮兵阵地

    目录 今天知识点 dp每个票的使用情况,然后更新此票状态下的最优解,dp到没有票就行了 把状态压缩成j,dp每行i的种植状态,从i-1行进行不断转移 把状态压缩成j,dp每行i的布置状态,从i-1和i-2行进行不断转移 POJ2686马车旅行 思路: POJ3254 玉米田 思路: POJ1185:炮兵阵地 思路:

    2024年02月04日
    浏览(51)
  • (动态规划) 剑指 Offer 60. n个骰子的点数 ——【Leetcode每日一题】

    难度:中等 把 n 个骰子扔在地上,所有骰子朝上一面的点数之和为 s 。输入 n ,打印出s的所有可能的值出现的概率。 你需要用一个浮点数数组返回答案,其中第 i 个元素代表这 n 个骰子所能掷出的点数集合中第 i 小的那个的概率。 示例 1: 输入: 1 输出: [0.16667,0.16667,0.16667,

    2024年02月11日
    浏览(41)
  • <算法学习>动态规划

    目录 一、超级台阶问题。 二、矩阵最短路径 三、最长递增子序列 四、最大连续子段和 五、最长公共子序列 六、0-1背包问题 七、找零问题 动态规划的基础知识和例题在这篇文章里列的很详细。 C++动态规划详解 在这里针对每道例题的解法多解释一下,方便以后复习回看。

    2024年02月21日
    浏览(29)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包