LeetCode 740. 删除与获得点数(排序+动态规划)

文章目录

    • 1. 题目
    • 2. 解题

1. 题目

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

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

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

示例 1:
输入: nums = [3, 4, 2]
输出: 6
解释: 
删除 4 来获得 4 个点数,因此 3 也被删除。
之后,删除 2 来获得 2 个点数。总共获得 6 个点数。示例 2:
输入: nums = [2, 2, 3, 3, 3, 4]
输出: 9
解释: 
删除 3 来获得 3 个点数,接着要删除两个 24 。
之后,再次删除 3 获得 3 个点数,再次删除 3 获得 3 个点数。
总共获得 9 个点数。注意:
nums的长度最大为20000。
每个整数nums[i]的大小都在[1, 10000]范围内。

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

2. 解题

  • 先预处理出每个数字的分数,并且按数字排序,使用map
  • dp[i][0] 表示不拿, dp[i][1] 表示拿 i 号数字时的最大得分
class Solution {
public:int deleteAndEarn(vector<int>& nums) {if(nums.empty())return 0;map<int,int> num_points;for(int num : nums)num_points[num] += num;//数字和其对应的分数vector<pair<int,int>> num_pts(num_points.begin(), num_points.end());//map key有序vector<vector<int>> dp(num_points.size(), vector<int>(2, 0));// dp[i][0] 表示不拿, dp[i][1] 表示拿 i 号数字的最大得分dp[0][1] = num_pts[0].second;//拿第一个数的得分for(int i = 1; i < num_pts.size(); ++i){if(num_pts[i-1].first+1 < num_pts[i].first)//数字间隔大于1dp[i][1] = num_pts[i].second + max(dp[i-1][0], dp[i-1][1]);//前一个数可以拿或者不拿else // num_pts[i-1].first+1 == num_pts[i].first 间隔1//我要拿了,前一个不能拿dp[i][1] = num_pts[i].second + dp[i-1][0];dp[i][0] = max(dp[i-1][0], dp[i-1][1]);	//我不拿,那么前一个拿或者不拿}return max(dp.back()[0], dp.back()[1]);}
};

20 ms 10.4 MB


我的CSDN博客地址 https://michael.blog.csdn.net/

长按或扫码关注我的公众号(Michael阿明),一起加油、一起学习进步!
Michael阿明

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/474004.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

多线程编程-条件变量

转载自&#xff1a;http://blog.chinaunix.net/uid-21411227-id-1826890.html 1&#xff0e;引言&#xff1a; 条件变量是一种同步机制&#xff0c;允许线程挂起&#xff0c;直到共享数据上的某些条件得到满足。条件变量上的基本操作有&#xff1a;触发条件(当条件变为 true 时…

html-css练习题 (注册表单)

代码赏析&#xff1a; <!DOCTYPE html> <html lang"en"> <head> <meta charset"UTF-8"> <meta name"viewport" content"widthdevice-width, initial-scale1.0"> <meta http-equiv"X-UA-Co…

虚拟机安装 服务器 Ubuntu Server20.04.2

虚拟机安装 服务器 Ubuntu Server20.04.2 下载地址 VMware创建新的虚拟机 首选选择典型 稍后安装操作系统&#xff0c;并点击下一步 选择Linux Ubuntu64位 命名虚拟机 指定虚拟机的容量 点击确定之后开启虚拟机 选择自己下载的镜像文件 打开虚拟机进行配置 单击…

LeetCode 838. 推多米诺(模拟)

文章目录1. 题目2. 解题1. 题目 一行中有 N 张多米诺骨牌&#xff0c;我们将每张多米诺骨牌垂直竖立。 在开始时&#xff0c;我们同时把一些多米诺骨牌向左或向右推。 每过一秒&#xff0c;倒向左边的多米诺骨牌会推动其左侧相邻的多米诺骨牌。 同样地&#xff0c;倒向右边…

html-css练习题(天天生鲜静态网页制作)文末有完整版代码地址链接

一、前言&#xff1a; 前端学习经典练手网页&#xff0c;重新整理网页版代码&#xff0c;如果你是初学者&#xff0c;请试着做一下这个网页 素材&#xff1a;文末完整版代码中。。。。。。 二、效果图&#xff1a; 三、主要需求&#xff1a; 1.login最外侧盒子设定高29 背景…

AutoIt: WinGetClassList可以把当前窗口所有的handle全部列出来

WinGetClassList 是一个非常有用的函数&#xff0c;可以返回当前窗口中所有的handle。返回的是一个字符串&#xff0c;可以使用split函数来拆分之。 Opt("WinTitleMatchMode")$handle WinGetHandle(".NET Reactor v4.5.9.8 - Full Version")ConsoleWrite(…

xshell连接Linux Server

由于server环境下无法使用vmtools&#xff0c;所以推荐使用shell工具进行链接使用。下载的内容源自果核&#xff0c;使用方法&#xff1a; xhell压缩包里面有crack目录&#xff0c;将nslicense.dll文件覆盖到软件目录 xhellplus&#xff0c;将nslicense.dll文件分别覆盖到软件X…

小案例:搭建简易版王者荣耀英雄购买商城网页版

目录 一、网页赏析&#xff1a; 二、代码分三部分&#xff1a; 1、html代码&#xff1a; 2、main.css赏析&#xff1a; 3、初始化reset.css代码&#xff1a; 三、主要素材下载地址&#xff1a; 一、网页赏析&#xff1a; 二、代码分三部分&#xff1a; 1.html 2.初始化…

2020云栖大会编程限时抢答赛 - 早中晚3场题解

文章目录1. 云栖大会限时抢答赛 - 早间场2. 云栖大会限时抢答赛 - 午间场3. 云栖大会限时抢答赛 - 晚间场1. 云栖大会限时抢答赛 - 早间场 题目链接 该场次题目在 LeetCode 上有原题&#xff0c;题解链接如下&#xff1a; LeetCode 862. 和至少为 K 的最短子数组&#xff08…

xml语法

给机器看 CDATA 给人看 用<这些转义字符表示转载于:https://www.cnblogs.com/vinplezhang/p/3300216.html

RSA公钥体系 与在 ssh中免密的登陆的应用

一、秘钥体系 第一部分查看书籍为 北京大学出版社出版的 丘维声老师的 数学思维方式与创新 在之前安全协议的讲解中&#xff0c;很多的协议都是用了秘钥的这一概念&#xff0c;相信很多同学对这不求甚解&#xff0c;下面我来系统的介绍秘钥体系&#xff0c;并且证明一下如今…

JavaScript 书写方式与注释

JavaScript是运行在浏览器端的脚步语言&#xff0c;JavaScript主要解决的是前端与用户交互的问题&#xff0c;包括使用交互与数据交互。JavaScript是浏览器解释执行的&#xff0c;前端脚本语言还有JScript&#xff08;微软&#xff0c;IE独有&#xff09;&#xff0c;ActionScr…

用Sass创建MetaFizzy效果

来源&#xff1a;GBin1.com Hugo发现了一个绚丽的css效果应用于web中并教会你如何聪明的重建和使用它。两天前&#xff0c;我看见笔者Hugo在css帮助下重写MetaFizzy的效果&#xff0c;Hugo帮助我们找到了一个用于理解Sass的JavaScript源代码。但我认为他的代码仍有可改之处&…

LeetCode 823. 带因子的二叉树(动态规划)

文章目录1. 题目2. 解题1. 题目 给出一个含有不重复整数元素的数组&#xff0c;每个整数均大于 1。 我们用这些整数来构建二叉树&#xff0c;每个整数可以使用任意次数。 其中&#xff1a;每个非叶结点的值应等于它的两个子结点的值的乘积。 满足条件的二叉树一共有多少个&…

动态规划问题之背包模型(18题)

背包问题是动态规划问题的一大类型&#xff0c;下面我们对这个进行总结。 以 Acwing y中总结的 几个类型&#xff0c;我写了几个题解 应用知识点 01背包、完全背包 空间压缩的写法多维费用的背包问题&#xff0c;以及状态的不同表示对复杂度的 影响完全背包问题的三种求解方法…

JS变量与命名规范

js的变量 JavaScript 是一种弱类型语言&#xff0c;javascript的变量类型由它的值来决定。 定义变量需要用关键字 var 声明定义变量 - variable 格式: var是声明变量的关键词必须写,var和变量名之间必须有空格 var 变量名 一次声明一个变量 var 变量名 变量名, 一次同时声明多…

LeetCode LCP 22. 黑白方格画

文章目录1. 题目2. 解题1. 题目 小扣注意到秋日市集上有一个创作黑白方格画的摊位。 摊主给每个顾客提供一个固定在墙上的白色画板&#xff0c;画板不能转动。 画板上有 n * n 的网格。绘画规则为&#xff0c;小扣可以选择任意多行以及任意多列的格子涂成黑色&#xff0c;所选…

js获取元素的方法与属性

js获取元素的方法 可以使用内置对象document上的getElementById方法来获取页面上设置了id属性的元素&#xff0c;获取到的是一个html对象&#xff0c;然后将它赋值给一个变量 <scripttype"text/javascript"> var oDiv document.getElementById(div1); ale…

adb logcat 基本用法

入门android &#xff0c;至少需要了解 adb 吧&#xff0c;那么打 log 也是必不可少的了。 下面简单介绍一下 adb logcat 基本用法&#xff1a; Usage: logcat [options] [filterspecs]options include: -s Set default filter to silent. Like…

ubuntu server安装hadoop和spark,并设置集群

安装server请看本人的上一篇博客 Ubuntu Server 20.04.2 安装 先前准备工作 创建 hadoop用户 创建用户之后&#xff0c;输入一下指令重启 shutdown -r now登录 hadoop 用户 安装 ssh 和 vim 首先更新一下 apt 工具 sudo apt-get update然后安装vim sudo apt-get install…