寝癖頭の解法

学習中の覚え書きを投稿、更新していきます。

Aizu Online Judge in C++ #Volume20 : 2007 - Make Purse Light

Aizu Online Judge(AOJ)の過去問から、その提出コードの解答例です。

・問題 "Make Purse Light"
https://onlinejudge.u-aizu.ac.jp/problems/2007
・財布を軽くしよう
僕が作成、提出したコードは、以下のとおりです。

・Aizu Online Judge in C++ #Volume20 - 2007 : Make Purse Light
/*
Aizu Online Judge in C++ #Volume20 - 2007 : Make Purse Light
 https://onlinejudge.u-aizu.ac.jp/problems/2007
 提出コードの解答例
 https://neguse-atama.hatenablog.com
*/
#include<bits/stdc++.h>
using namespace std;
int coin[]={10,50,100,500};
int main(void){
    int a[4],b[4],k,c,s=1;
    while(cin>>c,c){
        if(s!=1)cout<<endl;
		s=-c;
		for(int i=0;i<4;i++)cin>>b[i],s+=b[i]*coin[i],a[i]=0;
		for(int i=0;i<4;i++)while(s>=coin[3-i])s-=coin[3-i],a[3-i]++;
		for(int i=0;i<4;i++){
			k=b[i]-a[i];if(k>0)cout<<coin[i]<<" "<<k<<endl;
		}
    }
    return 0;
}

設問の出典は、プログラミング問題のオンライン採点システム「Aizu Online Judge(AOJ)」です。
http://judge.u-aizu.ac.jp/onlinejudge/