Aizu Online Judge(AOJ)の過去問から、その提出コードの解答例です。
・問題 "Parentheses"
https://onlinejudge.u-aizu.ac.jp/problems/2490
・括弧のバランス
僕が作成、提出したコードは、以下のとおりです。
Aizu Online Judge in C++ #Volume24 : 2490 - Parentheses
/* Aizu Online Judge in C++ #Volume24 : 2490 - Parentheses https://onlinejudge.u-aizu.ac.jp/problems/2490 提出コードの解答例 https://neguse-atama.hatenablog.com */ #include<bits/stdc++.h> using namespace std; using ll=long long; int main(void){ ll n,x[1111],ans=0,m=0; char p[1111]; cin>>n; for(ll i=0;i<n;i++){ cin>>p[i]>>x[i]; if(p[i]=='('){ ans+=x[i]; }else if(p[i]==')'){ ans-=x[i]; } if(ans<0){ m++; } } cout<<((ans || m) ? "NO\n" : "YES\n"); return 0; }
設問の出典は、プログラミング問題のオンライン採点システム「Aizu Online Judge(AOJ)」です。
http://judge.u-aizu.ac.jp/onlinejudge/