2018-03-24 02:57:20 +08:00
|
|
|
// Recursion problem
|
|
|
|
//Given the denominations of currencies available in a system, find the number of ways an ATM machine can
|
|
|
|
//generate notes for an entered amount N.
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
|
2018-03-24 04:30:55 +08:00
|
|
|
int ways(int n, int a[], int k)
|
|
|
|
{
|
2018-03-24 02:57:20 +08:00
|
|
|
if(n<0 || k<0) return 0;
|
|
|
|
if(n == 0) return 1;
|
|
|
|
if(k == 0) return 0;
|
|
|
|
return ways(n, a, k-1) + ways(n-a[k-1], a, k);
|
|
|
|
}
|
|
|
|
|
2018-03-24 04:30:55 +08:00
|
|
|
int main()
|
|
|
|
{
|
|
|
|
int m;
|
|
|
|
int t;
|
|
|
|
int n;
|
2018-03-24 02:57:20 +08:00
|
|
|
|
2018-03-24 04:30:55 +08:00
|
|
|
printf("Number of coins? ");
|
|
|
|
scanf("%d", &m);
|
|
|
|
int coin[m], i;
|
|
|
|
for(i=0; i<m; i++)
|
|
|
|
{
|
|
|
|
printf("coin? ");
|
|
|
|
scanf("%d", &coin[i]);
|
|
|
|
}
|
|
|
|
|
|
|
|
printf("---- your requests --- \n");
|
|
|
|
while(1)
|
|
|
|
{
|
|
|
|
printf("amount? exit(0) ");
|
|
|
|
scanf("%d", &n);
|
|
|
|
if (!n)
|
|
|
|
{
|
|
|
|
break;
|
|
|
|
}
|
2018-03-24 02:57:20 +08:00
|
|
|
printf("%d\n", ways(n, coin, m));
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|