代码随想录 day44 完全背包

class Solution {

public:

int change(int amount, vector<int>& coins) {

vector <int> 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 dp[amount];

}

};

另外你这个是不能从大到小遍历的 因为这样的话 你就落下了重复选取的情况

class Solution {

public:

int combinationSum4(vector<int>& nums, int target) {

vector<int>dp(target+1,0);

dp[0]=1;

for(int i=0;i<=target;i++){

for(int j=0;j<nums.size();j++){

if(i-nums[j]>=0&& dp[i] < INT_MAX - dp[i - nums[j]])

dp[i]+=dp[i-nums[j]];

}

}

return dp[target];

}

};

第二题还是要小心啊 虽然看起来是排列 实际上是组合!!!

相关推荐
爱编程的鱼22 分钟前
C# 数组&C# 多维数组
数据结构·算法·c#
前端开发工程师请求出战1 小时前
MCP — 让AI变得更“百搭”
算法
人机与认知实验室1 小时前
人机环境空战矩阵
人工智能·线性代数·算法·机器学习·矩阵
百度Geek说2 小时前
5个技巧让文心快码成为你的后端开发搭子
后端·算法
上海迪士尼352 小时前
除自身以外数组的乘积是什么意思
数据结构·算法
数据智能老司机2 小时前
Python 实战遗传算法——遗传算法导论
python·算法·机器学习
咩?2 小时前
支持向量机(第二十九节课内容总结)
算法·机器学习·支持向量机
EulerBlind2 小时前
【机器学习】从KNN算法到图像风格迁移:原理与实践
人工智能·算法·机器学习
anscos2 小时前
设计仿真 | 从物理扫描到虚拟检具:Simufact Welding革新汽车零部件检测
人工智能·算法·汽车·软件
tianchang3 小时前
JS 排序神器 sort 的正确打开方式
前端·javascript·算法