Aizu Online Judge(AOJ)の過去問から、その提出コードの解答例です。
・問題 "Range Minimum Query"
https://onlinejudge.u-aizu.ac.jp/problems/DSL_2_A
・区間-最小値問題
僕が作成、提出したコードは、以下のとおりです。
Aizu Online Judge in C++ #DSL_2_A : Range Minimum Query
/* Aizu Online Judge in C++ #DSL_2_A : Range Minimum Query https://onlinejudge.u-aizu.ac.jp/problems/DSL_2_A 提出コードの解答例 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,INT_MAX); for(ll i=0;i<q;i++){ ll c,x,y; cin>>c>>x>>y; switch(c){ case 0: v[x]=y; break; case 1: auto it=min_element(v.begin()+x,v.begin()+y+1); cout<<*it<<endl; break; } } return 0; }
設問の出典は、プログラミング問題のオンライン採点システム「Aizu Online Judge(AOJ)」です。
http://judge.u-aizu.ac.jp/onlinejudge/