Aizu Online Judge(AOJ)の過去問から、その提出コードの解答例です。
・問題 "Range Sum Query"
https://onlinejudge.u-aizu.ac.jp/problems/DSL_2_B
・区間和問題
僕が作成、提出したコードは、以下のとおりです。
Aizu Online Judge in C++ #DSL_2_B : Range Sum Query
/* Aizu Online Judge in C++ #DSL_2_B : Range Sum Query https://onlinejudge.u-aizu.ac.jp/problems/DSL_2_B 提出コードの解答例 https://neguse-atama.hatenablog.com */ #include<bits/stdc++.h> using namespace std; using ll=long long; int main(void){ ll n,q; cin>>n>>q; vector<ll> v(n,0); for(ll i=0;i<q;i++){ ll c,x,y; cin>>c>>x>>y; if(c==0){ v[x-1]+=y; }else{ cout<<accumulate(v.begin()+x-1,v.begin()+y,0)<<endl; } } return 0; }
設問の出典は、プログラミング問題のオンライン採点システム「Aizu Online Judge(AOJ)」です。
http://judge.u-aizu.ac.jp/onlinejudge/