[动态规划] 删除并获得点数

devtools/2024/9/20 7:03:09/ 标签: 动态规划, 算法

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

每次操作中,选择任意一个 nums[i] ,删除它并获得 nums[i] 的点数。之后,你必须删除 所有 等于 nums[i] - 1 和 nums[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 个点数,接着要删除两个 2 和 4 。
之后,再次删除 3 获得 3 个点数,再次删除 3 获得 3 个点数。
总共获得 9 个点数。

提示:

  • 1 <= nums.length <= 2 * 104
  • 1 <= nums[i] <= 104

解题分析

这道题设计的比较巧妙,可以利用动态规划的思路来解决问题。我们先理解一下题目的意思,然后尝试将它转换为一个经典的动态规划模型。我们知道,如果我们选择了nums[i],那么我们就不能选择nums[i]-1和nums[i]+1,而题目要求我们获得最大点数,所以我们也应当选择所有的与nums[i]相等的那些数,也就是说假如与nums[i]相等的数有x个,那么我们就可以得到x * nums[i]个点数。接下来就有意思了,不妨创建一个数组sum,这个sum数组的特点是sum[nums[i]] = nums[i] * x。其中x为个数。这样我们创建一个dp数组,dp[i]表示到第i个位置的时候,我们隔位选座(也就是说我们如果选了sum[c],那么我们就不能选它相邻位置的sum[c-1] 和 sum[c+1]) 能够得到的最大点数。显然,我们有递推关系式 dp[i] = max(dp[i-1],dp[i-2]+sum[i])。也就是说,如果我们选择第i个位置,那我们可以得到第i个位置的点数sum[i] 加上 我们到第i-2个位置时选座的最大点数。如果我们不选择第i个位置,那我们就可以考虑选第i-1个位置,而我们又确定了不选第i个位置,所以得到dp[i]就直接等于dp[i-1]即可。最后输出dp[n-1]即可。 

代码实现

class Solution {
private:int rob(vector<int> &nums){int n = nums.size();vector<long long> dp(n);dp[0]=nums[0];dp[1]=max(nums[0],nums[1]);for(int i=2;i<n;i++){dp[i]=max(dp[i-2]+nums[i],dp[i-1]);}return dp[n-1];}
public:int deleteAndEarn(vector<int>& nums) {int maxVal = 0;for(int val : nums){maxVal = max(maxVal,val);}vector<int> sum(maxVal+1);for(int val:nums){sum[val] += val;}return rob(sum);}
};


http://www.ppmy.cn/devtools/109022.html

相关文章

国内短剧系统怎么搭建以及都需要那些资质?

聊到国内短剧&#xff0c;相信大家都不陌生&#xff0c;在各大短视频平台可谓是火的一批&#xff0c;您或许有想加入进来的想法&#xff0c;或是已经有规划还未实现的&#xff0c;请停下脚步&#xff0c;耐心看完该文章&#xff0c;相信一定会对你有所帮助的。本文介绍短剧平台…

做饭时用什么样的白酒能更好衬托食物的鲜味?

在做饭的时候&#xff0c;白酒扮演着举足轻重的角色&#xff0c;其核心功能在于祛除食材不良风味并显著提升菜肴的香醇层次。挑选适宜的白酒时&#xff0c;需细致考量其种类与酒精浓度&#xff0c;尽量与食材的风味和谐共生&#xff0c;而非相互抵触。以下是酱酒亮哥yutengtrad…

LeetCode HOT100系列题解之最大正方形(6/100)

题目&#xff1a;最大正方形. - 力扣&#xff08;LeetCode&#xff09; 题解&#xff1a; 第一种方法&#xff1a;前缀和二分答案&#xff08;暴力优化&#xff09;我感觉比官方给的暴力好一点 时间复杂度&#xff1a; 暴力优化1&#xff1a;通过前缀和减少判断1出现得次数…

SpringBoot教程(十五) | SpringBoot集成RabbitMq(消息丢失、消息重复、消息顺序、消息顺序)

SpringBoot教程&#xff08;十五&#xff09; | SpringBoot集成RabbitMq&#xff08;消息丢失、消息重复、消息顺序、消息顺序&#xff09; RabbitMQ常见问题解决方案问题一&#xff1a;消息丢失的解决方案&#xff08;1&#xff09;生成者丢失消息丢失的情景解决方案1&#xf…

Elasticsearch之原理详解

简介 ES是使用 Java 编写的一种开源搜索引擎&#xff0c;它在内部使用 Lucene 做索引与搜索&#xff0c;通过对 Lucene 的封装&#xff0c;隐藏了 Lucene 的复杂性&#xff0c;取而代之的提供一套简单一致的 RESTful API 然而&#xff0c;Elasticsearch 不仅仅是 Lucene&#…

【ES备份和还原索引数据】

文章目录 备份&#xff08;Snapshot&#xff09;还原&#xff08;Restore&#xff09;注意事项示例 在 Elasticsearch 中&#xff0c;备份和还原索引数据通常通过快照&#xff08;Snapshot&#xff09;和恢复&#xff08;Restore&#xff09;机制来实现。以下是详细的操作步骤&…

【RabbitMQ】核心概念

界⾯上的导航栏共分6部分, 这6部分分别是什么意思呢, 我们先看看RabbitMQ的工作流程 1. Producer和Consumer Producer:生产者,是RabbitMQ Server的客户端,向RabbitMQ发送消息 Consumer: 消费者,也是RabbitMQ Server的客户端,从RabbitMQ接收消息 Broker:其实就是RabbitMQSer…

策略规划:在MySQL中实现数据恢复的全面指南

数据恢复是数据库管理中至关重要的一环&#xff0c;它确保在发生数据丢失或损坏的情况下&#xff0c;能够迅速且准确地恢复数据。在MySQL中&#xff0c;实现有效的数据恢复策略规划需要综合考虑备份策略、备份类型、存储管理、故障转移机制以及恢复流程。本文将深入探讨如何在M…

springcloud-GateWay

Spring Cloud Gateway 是 Spring Cloud 微服务架构中的一个重要组件&#xff0c;用于提供 API 网关功能。作为 API 网关&#xff0c;Spring Cloud Gateway 充当客户端和后端服务之间的代理&#xff0c;负责请求路由、过滤、安全认证、负载均衡等功能。在分布式系统中&#xff0…

2024数学建模国赛B题代码

B题已经完成模型代码&#xff01;详情查看文末名片 问题1&#xff1a;可以考虑使用统计学中的“样本量估算”方法&#xff0c;使用二项分布或正态近似来决定最少的样本量&#xff0c;并通过假设检验&#xff08;如单侧检验&#xff09;在95%和90%置信度下进行判断。 import n…

漫谈设计模式 [6]:适配器模式

引导性开场 菜鸟&#xff1a;老鸟&#xff0c;我最近在项目中遇到一个问题&#xff0c;我们的系统需要集成一个新的第三方库&#xff0c;但这个库的接口和我们现有的代码完全不兼容。我该怎么办&#xff1f; 老鸟&#xff1a;这是个常见的问题&#xff0c;很多开发者都会遇到…

浙大数据结构:03-树3 Tree Traversals Again

这道题也不算难&#xff0c;我依然采用map来进行处理 &#xff0c;代码依旧较短 机翻 1、条件准备 我这里采用数组模拟栈&#xff0c;tt指向栈顶&#xff1b; map的键存结点值&#xff0c;后面数对存左右子树的结点值 head存头节点的值 #include<iostream> #include…

【自动驾驶】控制算法(八)横向控制Ⅰ | 算法与流程

写在前面&#xff1a; &#x1f31f; 欢迎光临 清流君 的博客小天地&#xff0c;这里是我分享技术与心得的温馨角落。&#x1f4dd; 个人主页&#xff1a;清流君_CSDN博客&#xff0c;期待与您一同探索 移动机器人 领域的无限可能。 &#x1f50d; 本文系 清流君 原创之作&…

go-gin响应被覆盖为400,即使正常返回

问题描述及排查过程 一个正常响应里&#xff0c;http状态码为400&#xff0c;但实际已经成功返回了数据&#xff0c;且无论是自己写的业务逻辑代码还是中间件都没有返回400&#xff08;bad request&#xff09;这个状态码。 而且gin debug日志中也提示说有操作试图将状态码40…

基于EPS32C3电脑远程开机模块设计

基于EPS32C3电脑远程开机模块设计 前言 缘起&#xff0c;手头资料太多了&#xff0c;所以想组一台NAS放在家里存储数据。在咸鱼淘了一套J3160主板加机箱&#xff0c;加上几块硬盘组建NAS。 对于NAS&#xff0c;我的需求是不用的时候关机(节省功耗)&#xff0c;要用的时候开机…

Web

关于Web Web是基于HTTP协议进行交互的应用网络Web就是通过使用浏览器/APP访问的各种资源 一个请求对应一个响应 eg. 淘宝网 输入一个url&#xff0c;就会返回一个页面 简单的网站开发 简单代码 package mainimport ("fmt""net/http" )/*http.ResponseWr…

linux 链接库时 -I(大写i)、-L、-l(小写l) 选项的含义

-I(大写i) 选项 -I 选项用于指定编译器在搜索头文件时应该包括的额外目录。当编译器在编译过程中遇到#include指令时&#xff0c;它会在标准路径&#xff08;如/usr/include&#xff09;和通过-I指定的路径中查找指定的头文件。 # 在这个例子中&#xff0c;编译器会在/usr/loc…

【内网】ICMP出网ew+pingtunnel组合建立socks5隧道

❤️博客主页&#xff1a; iknow181 &#x1f525;系列专栏&#xff1a; 网络安全、 Python、JavaSE、JavaWeb、CCNP &#x1f389;欢迎大家点赞&#x1f44d;收藏⭐评论✍ 通过环境搭建&#xff0c;满足以下条件&#xff1a; 攻击机模拟公网vps地址&#xff0c;WEB边界服务器(…

Web服务器配置管理

目录 一、设计内容&#xff1a; 二、摘 要 三、课题描述 四、需求分析 五、概要设计 六、详细设计 七、结果分析 八、总结 一、设计内容 Web服务器的安装与配置管理。 1.任务说明 C/S 模式的网络环境&#xff0c;包括一台Windows工作站和一台Windows Server 服务器。 2.要求 ①…

redis之缓存淘汰策略

1.查看redis的最大占用内存 使用redis-cli命令连接redis服务端&#xff0c;输入命令&#xff1a;config get maxmemory 输出的值为0&#xff0c;0代表redis的最大占用内存等同于服务器的最大内存。 2.设置redis的最大占用内存 编辑redis的配置文件&#xff0c;并重启redis服务…