网站首页 > 技术文章 正文
习题
本题为leetcode 740题
给你一个整数数组 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 个点数。
思路
对于数组nums中的每一个元素,我们都可以选择获取它的值或者删除它
所以对于每一个数字,是否选择它可以基于两种前置结果:
- 如果不选择当前位置的数字,那得到的就是前一个位置数字的最优解
- 如果选择当前位置的数字,那得到的就是前前位置数字的最优解加上当前位置数字的最优解乘以数字个数
所以本题可以采用动态规划的方式来进行解答
使用一个map来保存每个数字出现的个数
接下来写出递归公式
dp[0] = 0
dp[1] 是数字1 出现的次数
dp[i] = max(dp[i - 1], dp[i - 2] + i * map[i])
解答
var deleteAndEarn = function(nums) {
var map = {},
numCount = 0,
dp = [0];
nums.forEach(function(item) {
if (map[item]) {
map[item] = map[item] + 1;
} else {
map[item] = 1;
if (item > numCount) {
numCount = item;
}
}
})
if (map[1]) {
dp[1] = map[1];
} else {
dp[1] = 0;
}
for (var i = 2; i <= numCount; i++) {
dp[i] = Math.max(dp[i - 1], dp[i - 2] + i * (map[i] || 0));
}
return dp.pop();
};
- 上一篇: 前端算法题:解码异或后的数组——位运算
- 下一篇: 前端面试题 前端面试题及答案
猜你喜欢
- 2025-06-18 盘点机器人常用的几大主流SLAM算法
- 2025-06-18 蚂蚁金服软件测试工程师一面面试题(附答案)建议收藏
- 2025-06-18 142道最新的Linux面试题及解析!代码清晰直接套用
- 2025-06-18 字节跳动的算法面试题是什么难度?
- 2025-06-18 史上最全的字节跳动 Java 面试题集锦,高级 Java 工程师面试技术
- 2024-10-04 前端面试题(最近) 前端面试题2021及答案
- 2024-10-04 前端基础知识汇总(一) 前端知识梳理
- 2024-10-04 面试笔试算法题 面试算法题是手写吗
- 2024-10-04 2W字!梳理50道经典计算机网络面试题(收藏版)
- 2024-10-04 数组遍历:JavaScript算法题的解题利器
你 发表评论:
欢迎- 533℃Oracle分析函数之Lag和Lead()使用
- 531℃几个Oracle空值处理函数 oracle处理null值的函数
- 529℃Oracle数据库的单、多行函数 oracle执行多个sql语句
- 521℃0497-如何将Kerberos的CDH6.1从Oracle JDK 1.8迁移至OpenJDK 1.8
- 515℃Oracle 12c PDB迁移(一) oracle迁移到oceanbase
- 505℃【数据统计分析】详解Oracle分组函数之CUBE
- 485℃最佳实践 | 提效 47 倍,制造业生产 Oracle 迁移替换
- 483℃Oracle有哪些常见的函数? oracle中常用的函数
- 最近发表
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端缓存 (63)
- 前端react (48)
- 前端aes加密 (58)
- 前端脚手架 (56)
- 前端md5加密 (54)
- 前端富文本编辑器 (47)
- 前端路由 (61)
- 前端数组 (73)
- 前端排序 (47)
- 前端密码加密 (47)
- Oracle RAC (73)
- oracle恢复 (76)
- oracle 删除表 (48)
- oracle 用户名 (74)
- oracle 工具 (55)
- oracle 内存 (50)
- oracle 导出表 (57)
- oracle 中文 (51)
- oracle的函数 (57)
- 前端调试 (52)
- 前端登录页面 (48)
本文暂时没有评论,来添加一个吧(●'◡'●)