国内最全IT社区平台 联系我们 | 收藏本站
华晨云阿里云优惠2
您当前位置:首页 > 互联网 > 硬币问题

硬币问题

来源:程序员人生   发布时间:2014-09-17 20:12:15 阅读次数:2596次

不同的面值Value[ ]有硬币个数Num[ ]限制,凑齐Goal面值,需要的最小和最大个数。

static int Min = 1<<10; static int Max = 0; static int* set; static int* Count; void LeastCoin_N(int* Value, int* Num, int Len, int Goal, int cur) { if(Goal == 0) { if(cur > Max) { for(int i = 0; i < Len; i++) { for(int j = 0; j < cur; j++) { if(Value[i] == set[j]) { Count[i]++; if(Count[i] > Num[i]) { goto initial; } } } } for(int i = 0; i < cur; i++) { printf("%d ", set[i]); } Max = cur; } if(Min > cur) { for(int i = 0; i < Len; i++) { for(int j = 0; j < cur; j++) { if(Value[i] == set[j]) { Count[i]++; if(Count[i] > Num[i]) { goto initial; } } } } for(int i = 0; i < cur; i++) { printf("%d ", set[i]); } Min = cur; } initial: memset(Count, 0 , sizeof(int)*Len); printf(" "); } else { for(int i = 0; i < Len; i++) { if(Goal >= Value[i]) { int ok = 1; for(int j = 0; j < cur; j++) { if(set[j] > Value[i]) { ok = 0; break; } } if(ok) { set[cur] = Value[i]; LeastCoin_N(Value, Num, Len, Goal - Value[i], cur + 1); } } } } } int WLeastCoin_N(int* Value, int* Num, int Len,int Goal) { printf("goal: %d ", Goal); set = new int [Len]; memset(set, 0 , sizeof(int)*Len); Count = new int [Len]; memset(Count, 0 , sizeof(int)*Len); int cur = 0; LeastCoin_N(Value, Num, Len, Goal, cur); printf("Max:%d ", Max); printf("Min:%d ", Min); return 0; }


生活不易,码农辛苦
如果您觉得本网站对您的学习有所帮助,可以手机扫描二维码进行捐赠
程序员人生
------分隔线----------------------------
分享到:
------分隔线----------------------------
关闭
程序员人生