zoukankan      html  css  js  c++  java
  • 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     else
    40         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
    ",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 }
    View Code
  • 相关阅读:
    1083 List Grades (25 分)
    1075 PAT Judge (25 分)
    15. 会话之session
    我的编程路----
    jQuery
    CSS
    HTML display 属性 和 行内元素、块状元素、行内块状元素的区别
    实例1 : 返回顶部小操作(JQ + JS 实现)
    jQuery 事件方法
    为什么静态方法 不可以 被 非静态方法调用?
  • 原文地址:https://www.cnblogs.com/chujian123/p/3840717.html
Copyright © 2011-2022 走看看