TheAlgorithms-C/misc/demonetization.c

43 lines
811 B
C
Raw Normal View History

// 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)
{
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 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;
}
printf("%d\n", ways(n, coin, m));
}
return 0;
}