조회 수 856 추천 수 0 댓글 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
번호 제목 글쓴이 날짜 조회 수
공지 글쓰기는 하루 5개, 댓글은 10개만 가능합니다. 좋은아빠되기 2019.02.15 587
공지 키보드 화살표값 출력 좋은아빠되기 2016.11.19 1364
공지 원하는 좌표에 값 출력하기 좋은아빠되기 2016.11.19 2680
공지 Python(파이썬) 학습 자료 PDF 1 file 좋은아빠되기 2014.12.10 10847
공지 dev C++ 텍스트 색상변경 WinApi사용(textcolor 대용) 좋은아빠되기 2014.06.07 5012
공지 DEV-C++ 기본 코드 좋은아빠되기 2013.06.19 8720
공지 무료 C++ 컴파일러(윈도우용) DEV-C++ 좋은아빠되기 2013.06.18 19261
공지 이클립스 C++ 설치 파일들 좋은아빠되기 2013.06.18 38152
370 정올 반복제어문3 형성평가4 정승준 2018.03.10 257
369 정올 반복제어문3 형성평가3 정승준 2018.03.10 175
368 정올 반복제어문3 형성평가2 정승준 2018.03.10 138
367 정올 반복제어문3 형성평가1 정승준 2018.03.03 141
366 링크드 리스트 예제 조정미 2018.03.03 295
365 정올 반복제어문3 자가진단7 정승준 2018.03.03 150
364 정올 반복제어문3 자가진단4(반대) 정승준 2018.03.03 163
363 정올 반복제어문3 자가진단6 정승준 2018.03.03 225
362 정올 - 알고리즘 - 냉장고(1828) 조정미 2018.03.03 856
361 정올 - 알고리즘 - 짚신벌레(1822) - 완 조정미 2018.03.03 967
360 정올 - 알고리즘 - 짚신벌레(1822) - 미완2 조정미 2018.03.03 167
359 정올 - 알고리즘 - 짚신벌레(1822) - 미완 조정미 2018.02.24 235
» 정올 - 알고리즘 - 동전자판기(下)(1183) 조정미 2018.02.24 856
357 정올 - 알고리즘 - 벽장문의 이동(1409) 조정미 2018.02.10 598
356 정올 반복제어문3 자가진단5 정승준 2018.02.10 191
355 정올 - 알고리즘 - 회의실 배정(1370) 조정미 2018.02.10 997
354 정올 - 실력키우기 - 색종이(고)(1124) 조정미 2018.02.10 1291
353 정올 반복제어문3 자가진단4 정승준 2018.02.03 142
352 정올 - 실력키우기 - 후위표기법(1221) 조정미 2018.02.03 1085
351 정올 반복제어문3 자가진단2 정승준 2018.01.27 127
Board Pagination Prev 1 ... 3 4 5 6 7 8 9 10 11 12 ... 26 Next
/ 26