Aizu Online Judge(AOJ)の過去問から、その提出コードの解答例です。
・問題 "ICPC Calculator"
https://onlinejudge.u-aizu.ac.jp/problems/1602
・ICPC計算機
僕が作成、提出したコードは、以下のとおりです。
・Aizu Online Judge in C++ #Volume16 : 1602 - ICPC Calculator
/* Aizu Online Judge in C++ #Volume16 : 1602 - ICPC Calculator https://onlinejudge.u-aizu.ac.jp/problems/1602 提出コードの解答例 https://neguse-atama.hatenablog.com */ #include<bits/stdc++.h> using namespace std; using ll=long long; ll n,d[200],p; char c[200]; string s; ll f(){ if(48<=c[p] && c[p]<=57){ return c[p++]-48; } ll k=p++,ret=0; if(c[k]=='*'){ ret=1; } while(d[p]==d[k]+1){ if(c[k]=='*'){ ret*=f(); }else{ ret+=f(); } } return ret; } int main(void){ while(cin>>n,n){ for(ll i=0;i<200;i++){ d[i]=0; } for(ll i=0;i<n;i++){ cin>>s; d[i]=s.size(); c[i]=s[s.size()-1]; } p=0; cout<<f()<<endl; } return 0; }
設問の出典は、プログラミング問題のオンライン採点システム「Aizu Online Judge(AOJ)」です。
http://judge.u-aizu.ac.jp/onlinejudge/