当前位置: 首页 > news >正文

代码随想录算法训练营第三十七天-2|动态规划part2

开始完全背包

注意01背包与完全背包的区别

518. 零钱兑换 II

题目链接:518. 零钱兑换 II - 力扣(LeetCode)

文章讲解:代码随想录

思路:

用dp【i】【j】表示从0-i任选硬币 有多少种方法装满背包j

递推公式:

dp[i][j] = dp[i - 1][j] +  dp[i][j - coins[i]];

class Solution {
public:int change(int amount, vector<int>& coins) {//定义dp【i】【j】表示从0-i任选硬币 有多少种方法装满背包jvector<vector<double>>dp(coins.size(),vector<double>(amount+1,0));//初始化for(int j=0;j<=amount;j++){if(j%coins[0]==0) dp[0][j]=1;}for(int i=0;i<coins.size();i++){dp[i][0]=1;}for(int i=1;i<coins.size();i++){for(int j=1;j<=amount;j++){if (coins[i] > j) dp[i][j] = dp[i - 1][j]; else dp[i][j] = dp[i - 1][j] +  dp[i][j - coins[i]];//容量为j 不放物品i有dp[i - 1][j]多种方法//容量为j - coins[i] 物品i 有dp[i][j- coins[i]]种方法}}return int(dp[coins.size()-1][amount]);      }
};

事实上 这道题类似于01背包问题的目标和 这是一道完全背包的目标和 

区别在于遍历顺序为从头到尾遍历

class Solution {
public:int change(int amount, vector<int>& coins) {//类似目标和vector<double>dp(amount+1,0);//dp[0]=1;for(int i=0;i<coins.size();i++){for(int j=coins[i];j<=amount;j++){dp[j]+=dp[j-coins[i]];}}return int(dp[amount]);}
};

377. 组合总和 Ⅳ

题目链接:377. 组合总和 Ⅳ - 力扣(LeetCode)

文章讲解:代码随想录

思路:

这道题与上题的零钱兑换二很像 区别在于 这是排列问题

所以遍历顺序有要求

因为上题的遍历先遍历物品 所以隐含了一个物品的排列顺序 一种特定的排列顺序

那么本题 先遍历背包 即在背包容量为j下能有多少种装法(包含了不同排列顺序了的)

所以先遍历背包容量 

class Solution {
public:
int combinationSum4(vector<int>& nums, int target) {vector<long>dp(target+1,0);dp[0]=1;for(int j=0;j<=target;j++){for(int i=0;i<nums.size();i++){if(j-nums[i]>=0&&dp[j]<LONG_MAX-dp[j-nums[i]]){            dp[j]+=dp[j-nums[i]];}}}return dp[target];
}
};

http://www.xdnf.cn/news/334045.html

相关文章:

  • [5-2] 对射式红外传感器计次旋转编码器计次 江协科技学习笔记(38个知识点)
  • 服务器数据恢复—Linux操作系统服务器意外断电导致部分文件丢失的数据恢复
  • 力扣刷题Day 41:除自身以外数组的乘积(238)
  • 【Linux】Linux工具(1)
  • 基于Centos7的DHCP服务器搭建
  • 【MySQL】存储引擎 - MyISAM详解
  • ARM 芯片上移植 Ubuntu 操作系统详细步骤
  • 云原生架构下的企业数字化转型之路:理念、挑战与落地实战
  • 2. Windows+Msys2+QGis3.36.1编译运行
  • 【Python开源】深度解析:一款高效音频封面批量删除工具的设计与实现
  • Axios替代品Alova
  • nutui-uniapp项目:弹框、弹出层的组件选择问题(组件对比)
  • 基于腾讯云MCP广场的AI自动化实践:爬取小红书热门话题
  • STM32系统定时器以及微秒延时函数分析
  • 电池自动分选机:新能源时代的“质检卫士”
  • Excel学习笔记
  • 蓝桥杯第十六届c组c++题目及个人理解
  • C++入门(下)--《Hello C++ World!》(2)(C/C++)
  • 【C++】手搓一个STL风格的string容器
  • 【开源解析】基于Python的智能文件备份工具开发实战:从定时备份到托盘监控
  • 键盘固件刷写详解:Bootloader
  • AppInventor2如何实现写文件不覆盖,而是在文件尾部追加?
  • 使用 React 实现语音识别并转换功能
  • Java游戏服务器开发流水账(2)开发中Maven的管理
  • CROSS 技术全解析:边缘计算如何成为行业价值新引擎
  • Linux下使用openssh搭建sftp服务
  • SQL:MySQL函数:字符串函数
  • 金仓数据库征文-金仓KES数据同步优化实践:逻辑解码与增量同步
  • 深入理解负载均衡:传输层与应用层的原理与实战
  • KRaft (Kafka 4.0) 集群配置指南(超简单,脱离 ZooKeeper 集群)还包含了简化测试指令的脚本!!!