有数组penny,penny中所有的值都为正数且不重复。每个值代表一种面值的货币,每种面值的货币可以使用任意张,再给定一个整数aim(小于等于1000)代表要找的钱数,求换钱有多少种方法。
给定数组penny及它的大小(小于等于50),同时给定一个整数aim,请返回有多少种方法可以凑成aim。
[1,2,4],3,3
返回:2
class Exchange {
public:
int countWays(vector<int> penny, int n, int aim) {
// write code here
vector<vector<int>> map(penny.size()+1,vector<int>(aim+1,0));
return help(penny,0,aim,map);
}
int help(vector<int> penny,int index,int aim,vector<vector<int>> &map)
{
int ret=0;
if(index==penny.size())
return aim==0?1:0;
else{
int value=0;
for(int i=0;i*penny[index]<=aim;i++)
{
value=map[index+1][aim-i*penny[index]];
if(value!=0)
ret+=value==-1?0:value;
else
ret+=help(penny,index+1,aim-i*penny[index],map);
}
}
map[index][aim]=ret==0?-1:ret;
return ret;
}
};