| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 数据结构与算法 -> 2021-08-09 -> 正文阅读 |
|
[数据结构与算法]2021-08-09 |
1.倒酒:一道裸的拓欧,复习一下板子 2.Golden Feather: 3.硬币购物:其实这道题挺巧妙的,这个数据就一直给我们提示,不可能多重背包暴力做,T飞了。所以一定是预处理好完全背包,再考虑怎么得到答案。 ①dp[i],因为需要预处理,所以表示选择前四个物品的完全背包,而又怎么与多重背包关联起来呢?我们发现每个物品i最多只能选di个,意味着第i个物品占(di+1)*ci个体积及以上是不可能的,而这个方案数就是dp[v-(di+1)*ci],把这个减掉就行了。 ②但是这是否做了对集合枚举的不重不漏呢?答案是否定的,在保证第1件物品多用了的同时,无法保证其他物品没有多用,所以dp[v-(d1+1)*c1]实际上把第2件物品多用,第3件物品多用......包含进去了,用二进制来说就是1000,1001,1010,1011,1100,1101,1110,1111这几种状态 代码不难,思路确实有点新颖 |
|
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 | -2024/11/25 20:39:51- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |