#include <iostream> #include <cstdio> #include <cstring> #include <cmath> #include <algorithm> #include <climits> #include <vector> #include <queue> #include <cstdlib> #include <string> #include <set> #include <stack> #define LL long long #define pii pair<int,int> #define INF 0x3f3f3f3f using namespace std; const int maxn = 10010; struct node{ int lt,rt,minv; }; node tree[maxn<<2]; void build(int lt,int rt,int v){ tree[v].lt = lt; tree[v].rt = rt; if(lt == rt){ scanf("%d",&tree[v].minv); return; } int mid = (lt + rt)>>1; build(lt,mid,v<<1); build(mid+1,rt,v<<1|1); tree[v].minv = min(tree[v<<1].minv,tree[v<<1|1].minv); } void update(int p,int val,int v){ if(tree[v].lt == tree[v].rt){ tree[v].minv = val; return; } if(p <= tree[v<<1].rt) update(p,val,v<<1); if(p >= tree[v<<1|1].lt) update(p,val,v<<1|1); tree[v].minv = min(tree[v<<1].minv,tree[v<<1|1].minv); } int query(int lt,int rt,int v){ if(tree[v].lt >= lt && tree[v].rt <= rt) return tree[v].minv; int a = INF,b = INF; if(lt <= tree[v<<1].rt) a = query(lt,rt,v<<1); if(rt >= tree[v<<1|1].lt) b = query(lt,rt,v<<1|1); return min(a,b); } int main() { int n,m,op,u,v; while(~scanf("%d",&n)){ build(1,n,1); scanf("%d",&m); while(m--){ scanf("%d %d %d",&op,&u,&v); if(op) update(u,v,1); else printf("%d\n",query(u,v,1)); } } return 0; }