데이터 구조 탐욕 법 학습 노트

거스름돈 의 장 수 를 자동 으로 계산 하 다.
#include<stdio.h>
#define MAXN 9
int parvalue[MAXN] = {10000,5000,1000,500,200,100,50,20,10};
int num[MAXN] = {0};
int exchange(int n)
{
	int i,j;
	for(i=0;i<MAXN;i++)
		if(n>parvalue[i]) break;
	while(n>0 && i<MAXN)
	{
		if(n>=parvalue[i])
		{
			n -=parvalue[i];
			num[i]++;
		}else if(n<10 && n>=5)
		{
			num[MAXN-1]++;
			break;
		}else i++;
		
	}
	return 0;
}

int main()
{
	int i;
	float m;
	printf("        :");
	scanf("%f",&m);
	exchange((int)100*m);
	printf("
%.2f :
",m); for(i=0;i<MAXN;i++) if(num[i]>0) printf("%6.2f: %d
",(float)parvalue[i]/100.0,num[i]); getch(); return 0; }

좋은 웹페이지 즐겨찾기