class Solution {
public:
int change(int amount, vector<int>& coins) {
vector <int> dp(amount+1,0);
dp0=1;
for(int i=0;i<coins.size();i++){
for(int j=coinsi;j<=amount;j++){
dpj+=dpj-coins\[i];
}
}
return dpamount;
}
};
另外你这个是不能从大到小遍历的 因为这样的话 你就落下了重复选取的情况
class Solution {
public:
int combinationSum4(vector<int>& nums, int target) {
vector<int>dp(target+1,0);
dp0=1;
for(int i=0;i<=target;i++){
for(int j=0;j<nums.size();j++){
if(i-numsj>=0&& dpi < INT_MAX - dpi - nums\[j])
dpi+=dpi-nums\[j];
}
}
return dptarget;
}
};
第二题还是要小心啊 虽然看起来是排列 实际上是组合!!!