Vues 886 Recommandés 0 Commentaire 0

#include <stdio.h>
int coin[6]={0}; //가지고 있는 동전의 개수 [0]=500원 [1]=100원 [2]=50원 [3]=10원 [4]=5원 [5]=1원
int answer[6]={0}; //내야하는 동전의 개수
int won[6]={500, 100, 50, 10, 5, 1};

int price(int w); //동전 개수 맞추기
int main(void)
{
	int w, i, result=0; //w=구입하려는 물건의 값

	//입력
	scanf(" %d", &w);

	for(i=0; i<6; i++)
		scanf(" %d", &coin[i]);

	//계산
	price(w);

	for(i=0; i<6; i++)
		result+=answer[i];

	//정답 출력
	printf("%d\n", result);

	for(i=0; i<6; i++)
		printf("%d ", answer[i]);

	return 0;
}
int price(int w)
{
	int sum=0, i, j, a, k, more, f;

	if(coin[5]>=(w%10)) //won[i]원의 개수가 물건의 값의 일의 자리 수보다 클 때
	{
		sum=w%10;
		answer[5]=w%10;
		coin[5]-=w&10;
	}
	else //won[i]원의 개수가 물건의 값의 일의 자리 수보다 작을 때
	{
		sum=w%10;
		answer[5]=(w%10)-5;
		coin[5]-=(w%10)-5;
		answer[4]++;
		coin[4]--;
	}

	for(i=4; i>=0; i--)
	{
		f=coin[i];
		for(j=1; j<=f; j++)
		{
			a=sum+won[i];
			if(a<=w) //물건 값보다 적거나 같은 경우
			{
				sum+=won[i];
				answer[i]++;
				coin[i]--;
				if(a==w)
					return 0;
			}
			else //물건 값보다 초과한 경우
			{
				more=a-w; //초과한 금액
				a-=more;
				for(k=i+1; k<6; k++) //초과한 금액만큼 최소한의 동전 개수로 빼내기
				{
					if(won[k]<=more)
					{
						coin[k]+=more/won[k];
						answer[k]-=more/won[k];
						more-=(more/won[k])*won[k];
					}
					if(more==0)
						break;
				}
				sum=a;
				answer[i]++;
				coin[i]--;
				if(a==w)
					return 0;
			}
		}
	}

	return 0;
}



List of Articles
No Titre Auteur Jour Vues
Notice 글쓰기는 하루 5개, 댓글은 10개만 가능합니다. 좋은아빠되기 2019.02.15 789
Notice 키보드 화살표값 출력 좋은아빠되기 2016.11.19 1551
Notice 원하는 좌표에 값 출력하기 좋은아빠되기 2016.11.19 2897
Notice Python(파이썬) 학습 자료 PDF 1 file 좋은아빠되기 2014.12.10 11325
Notice dev C++ 텍스트 색상변경 WinApi사용(textcolor 대용) 좋은아빠되기 2014.06.07 5222
Notice DEV-C++ 기본 코드 좋은아빠되기 2013.06.19 9050
Notice 무료 C++ 컴파일러(윈도우용) DEV-C++ 좋은아빠되기 2013.06.18 19490
Notice 이클립스 C++ 설치 파일들 좋은아빠되기 2013.06.18 38367
370 정올 반복제어문3 형성평가4 정승준 2018.03.10 277
369 정올 반복제어문3 형성평가3 정승준 2018.03.10 190
368 정올 반복제어문3 형성평가2 정승준 2018.03.10 155
367 정올 반복제어문3 형성평가1 정승준 2018.03.03 163
366 링크드 리스트 예제 조정미 2018.03.03 318
365 정올 반복제어문3 자가진단7 정승준 2018.03.03 176
364 정올 반복제어문3 자가진단4(반대) 정승준 2018.03.03 181
363 정올 반복제어문3 자가진단6 정승준 2018.03.03 250
362 정올 - 알고리즘 - 냉장고(1828) 조정미 2018.03.03 876
361 정올 - 알고리즘 - 짚신벌레(1822) - 완 조정미 2018.03.03 1000
360 정올 - 알고리즘 - 짚신벌레(1822) - 미완2 조정미 2018.03.03 194
359 정올 - 알고리즘 - 짚신벌레(1822) - 미완 조정미 2018.02.24 257
» 정올 - 알고리즘 - 동전자판기(下)(1183) 조정미 2018.02.24 886
357 정올 - 알고리즘 - 벽장문의 이동(1409) 조정미 2018.02.10 635
356 정올 반복제어문3 자가진단5 정승준 2018.02.10 212
355 정올 - 알고리즘 - 회의실 배정(1370) 조정미 2018.02.10 1021
354 정올 - 실력키우기 - 색종이(고)(1124) 조정미 2018.02.10 1384
353 정올 반복제어문3 자가진단4 정승준 2018.02.03 162
352 정올 - 실력키우기 - 후위표기법(1221) 조정미 2018.02.03 1107
351 정올 반복제어문3 자가진단2 정승준 2018.01.27 147
Board Pagination Prev 1 ... 3 4 5 6 7 8 9 10 11 12 ... 26 Next
/ 26