一、题目
二、思路
求组合数,不是求排列
三、代码
class Solution {
public:
int change(int amount, vector<int>& coins) {
int size=coins.size();
vector<int>dp(amount+1,0);
sort(coins.begin(),coins.end());
dp[0]=1;
//遍历数组
for(int i=0;i<size;++i){
//遍历金额
for(int j=coins[i];j<=amount;++j){
dp[j]+=dp[j-coins[i]];
}
}
return dp[amount];
}
};