首页 > 代码库 > RMQ with Shifts
RMQ with Shifts
uva12299:http://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem&problem=3720
题意:给你n个数,然后有两个操做,shift<a1,a2,a3.....ak>从左到右一次交换,即a1和a2交换,完了之后,a2和a3交换,以此类推。query<a1,a2>,查询a1到a2区间之间的最小值。
题解:一开始没有看懂题目,看错了,看懂之后,才发现是个水题,线段树区间查询,单点更新。不过读入要小心处理一下。
1 #include<iostream> 2 #include<cstdio> 3 #include<algorithm> 4 #include<cstring> 5 using namespace std; 6 const int N=100002; 7 int n,q,a[N]; 8 char str[10]; 9 int t1,t2;10 struct SegTree{11 int l,r;12 int minn;13 inline int mid(){14 return (l+r)/2;15 }16 }num[N*4];17 void pushup(int rt){18 num[rt].minn=min(num[rt<<1].minn,num[rt<<1|1].minn);19 }20 void build(int rt,int l,int r){21 num[rt].l=l;22 num[rt].r=r;23 if(l==r){24 num[rt].minn=a[l];25 return;26 }27 int mid=num[rt].mid();28 build(rt<<1,l,mid);29 build(rt<<1|1,mid+1,r);30 pushup(rt);31 }32 void update(int pos,int rt,int val){33 if(num[rt].l==num[rt].r){34 num[rt].minn=val;35 return;36 }37 int mid=num[rt].mid();38 if(mid>=pos)update(pos,rt<<1,val);39 else40 update(pos,rt<<1|1,val);41 pushup(rt);42 }43 int query(int rt,int l,int r){44 if(num[rt].l==l&&num[rt].r==r){45 return num[rt].minn;46 }47 int mid=num[rt].mid();48 if(mid>=r)return query(rt<<1,l,r);49 else if(mid<l)return query(rt<<1|1,l,r);50 else return min(query(rt<<1,l,mid),query(rt<<1|1,mid+1,r));51 }52 int main(){53 scanf("%d%d",&n,&q);54 for(int i=1;i<=n;i++){55 scanf("%d",&a[i]);56 }57 build(1,1,n);58 for(int i=1;i<=q;i++){59 scanf("%6s",str);//¶ÁÈ¡6¸ö×Ö·û60 if(str[0]==‘q‘){61 scanf("%d,%d)",&t1,&t2);62 printf("%d\n",query(1,t1,t2));63 }64 else{65 char c;66 int cnt=0;67 while (scanf("%d%c",&t2,&c)){68 cnt++;69 if(cnt==1){70 t1=t2;71 continue;72 }73 int temp=a[t1];74 a[t1]=a[t2];75 a[t2]=temp;76 update(t1,1,a[t1]);77 update(t2,1,a[t2]);78 t1=t2;79 if (c!=‘,‘) break;80 }81 }82 }83 }
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。