| |
|
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
| -> 数据结构与算法 -> 动态规划学习记录-7 删除并获得点数 -> 正文阅读 |
|
|
[数据结构与算法]动态规划学习记录-7 删除并获得点数 |
|
这题可以化成与打家劫舍相似的格式来求解 为什么这么说呢? 回忆打家劫舍,当小偷偷了当前房屋之后,就不再考虑上一间房屋和下一间房屋。 本题中,当取了某个数值num则不再考虑num-1和num+1。 但是不同点在于 打家劫舍的遍历是顺序的,从第一间房屋到最后一间房屋,但是本题中对数组的遍历是无序的,对于例子
我可以先获得4,之后消除3 也可以先获得3,之后消除4和2 并且,本题中数组的数值可能重复,可能出现如下情况:
为了简化计算,先考虑数组中重复的情况,就上面的情况而言,第一次取3,则会消除所有的2,之后再取3,则不会对当前数组产生任何影响,因为在第一次取出时就已经被消除了,所以可以利用桶排序,记录出现的次数,这样一来,简化了取?和?删除?这两个操作。 并且,如果对比桶排序后的数组和打家劫舍的数组,会发现它们的意义是惊人的相似, 对于当前房屋会有偷与不偷两种选项,同样的,对于当前的数,会有取与不取的情况, 偷当前房屋,则不考虑上一个房屋和下一个房屋,同样的,对于取当前的数,则不考虑上一个数字和下一个数字 所以,我们可以用桶排序后的数组用动态规划,代码与打家劫舍相似
|
|
|
|
|
| 上一篇文章 下一篇文章 查看所有文章 |
|
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
| 360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年11日历 | -2025/11/24 11:53:19- |
|
| 网站联系: qq:121756557 email:121756557@qq.com IT数码 |