Aizu Online Judge(AOJ)の過去問から、その提出コードの解答例です。
・問題 "Wrought Gold Master"
https://onlinejudge.u-aizu.ac.jp/problems/0201
・錬金マスター
僕が作成、提出したコードは、以下のとおりです。
・Aizu Online Judge in C++ #Volume2 - 0201 : Wrought Gold Master
/* Aizu Online Judge in C++ #Volume2 - 0201 : Wrought Gold Master https://onlinejudge.u-aizu.ac.jp/problems/0201 提出コードの解答例 https://neguse-atama.hatenablog.com */ #include<bits/stdc++.h> using namespace std; using ll=long long; int main(void){ ll n,m,x,y; string s,st; while(cin>>n,n){ map<string,ll> mp; for(ll i=0;i<n;i++){ cin>>s>>x; mp[s]=x; } cin>>m; for(ll i=0;i<m;i++){ y=0; cin>>s>>x; for(ll j=0;j<x;j++){ cin>>st; y+=mp[st]; } if(y<mp[s]){ mp[s]=y; } } cin>>s; cout<<mp[s]<<"\n"; } return 0; }
設問の出典は、プログラミング問題のオンライン採点システム「Aizu Online Judge(AOJ)」です。
http://judge.u-aizu.ac.jp/onlinejudge/