Time Limit: 1500/1000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Others)
Total Submission(s): 1308 Accepted Submission(s): 1038
//单点更新+区间查找 #include<iostream> #include <stdio.h> #include <string.h> using namespace std; const int Max = 1500; int MAXNUM; int a[Max]; struct Tree{ int Max; int r,l; }t[4*Max]; int MAX(int k,int j){ if(k>=j) return k; return j; } void build(int idx,int l,int r){ t[idx].l = l; t[idx].r=r; if(l==r){ t[idx].Max = a[l]; return; } int mid = (l+r)>>1; build(idx<<1,l,mid); build(idx<<1|1,mid+1,r); t[idx].Max = MAX(t[idx<<1].Max,t[idx<<1|1].Max); //父亲节点 } void query(int idx,int l,int r,int L,int R){ if(l>=L&&r<=R) { MAXNUM = MAX(MAXNUM,t[idx].Max); return; } int mid = (l+r)>>1; if(mid>=L) query(idx<<1,l,mid,L,R); if(mid<R) query(idx<<1|1,mid+1,r,L,R); } int main() { int tcase; scanf("%d",&tcase); while(tcase--){ int n; scanf("%d",&n); for(int i=1;i<=n;i++){ scanf("%d",&a[i]); } build(1,1,n); int m; scanf("%d",&m); for(int i=1;i<=m;i++){ int l,r; scanf("%d%d",&l,&r); MAXNUM = -999999999; query(1,1,n,l,r); printf("%d\n",MAXNUM); } } }