当前位置: 首页 > 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.dtcms.com/a/178274.html

相关文章:

  • CSS:字体和文本样式
  • Docker 常用命令
  • Google AI版图:解析AI Studio, Gemini, NotebookLM与GCP
  • 【Rust错误处理】Rust错误处理机制详解与应用实战
  • Yolo迁移训练-带训练源码
  • pip下载tmp不够
  • Git 基础操作系列2: 本地项目上传至git仓库(gitee / gitlab / github)
  • ITTIA DB Lite 9.x——一款高性能嵌入式事务型、时间序列嵌入式数据库
  • threejs 添加css3d标签 vue3
  • 自然语言到 SQL 转换:开启智能数据库交互新时代
  • cursor平替,试试 vscode+cline+openrouter 的方案,还能自定义 mcp-server 教程大纲
  • 【PostgreSQL数据分析实战:从数据清洗到可视化全流程】电商数据分析案例-9.2 流量转化漏斗分析
  • 企业微信自建消息推送应用
  • 技术视界 | 青龙机器人训练地形详解(三):复杂地形精讲之台阶
  • 二本计算机,毕业=失业?
  • 初识Linux · TCP基本使用 · 回显服务器
  • CROSS 技术全解析:边缘计算如何成为行业价值新引擎
  • [计算机科学#11]:编程语言简史,从二进制到简约表达的华丽转身,造就原因——“懒”
  • 解析小米大模型MiMo:解锁语言模型推理潜力
  • 线索二叉树
  • 服务器配置llama-factory问题解决
  • VR 南锣鼓巷:古老街区的数字化绘卷与沉浸式遨游​
  • 硬件选型:工控机的选择要素
  • 什么是 DDoS 攻击?从零到精通的全面解析
  • Tenorshare 4DDiG(数据恢复软件) v10.3.7.5 中文绿化版
  • shader中性能优化
  • 正则表达式实用指南:原理、场景、优化与引擎对比
  • 网络原理初识
  • VR制作软件用途(VR制作软件概述)
  • 【Python开源】深度解析:一款高效音频封面批量删除工具的设计与实现