• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            hdu3436(數(shù)據(jù)結(jié)構(gòu))

            //用樹狀數(shù)組實現(xiàn)求和和查詢第k個元素的功能
            #include <stdio.h>
            #include 
            <memory>
            #include 
            <iostream>
            #include 
            <algorithm>
            #include 
            <cstring>
            #include 
            <vector>
            #include 
            <map>
            #include 
            <cmath>
            #include 
            <set>
            #include 
            <queue>
            #include 
            <time.h> 
            #include 
            <limits>
            using namespace std;
            #define N 100005
            #define typev int 
            typev ar[N
            *2]; 
            int ks[N], num[N], pos[N], id[N];
            bool has[N]; 
            int kn, n, qn, fr; 
            char qs[N]; 
            int vMax; 
            int lowb(int t){ return t & (-t); }
            void add(int i, typev v){
                
            for(; i < vMax; ar[i] += v, i += lowb(i)) ; 
            }
            typev sum(
            int i){
                typev s 
            = 0;
                
            for(; i > 0; s += ar[i], i -= lowb(i));
                
            return s; 
            }
            int find_k(int k){ //find the kth number
                int pos = 0, cnt = 0, i; 
                
            for(i = log((double)vMax) / log(2.0+ 1; i >= 0; i--){
                    pos 
            += (1 << i); 
                    
            if(pos >= vMax || cnt + ar[pos] >= k) pos -= (1 << i); 
                    
            else cnt += ar[pos]; 
                }
                
            return pos + 1
            }
            bool input(){
                scanf(
            "%d%d"&n, &qn);
                
            int i; 
                
            char ops[10]; 
                
            for(i = 0; i < qn; i++){
                    scanf(
            "%s%d", ops, num+i);
                    ks[i] 
            = num[i]; 
                    qs[i] 
            = ops[0]; 
                }
                
            return true
            }
            void init(){
                kn 
            = qn; 
                ks[kn
            ++= 1
                sort(ks, ks
            +kn);  
                
            int i, j; 
                j 
            = 1;
                
            for(i = 1; i < kn; i++){
                    
            if(ks[i] != ks[j-1]) ks[j++= ks[i]; 
                }
                kn 
            = j; 
                vMax 
            = qn + kn + 1
                fill(ar, ar
            +vMax+10); 
                fr 
            = qn; 
            }
            int cnt = 0
            void solve(){
                
            int i, pMax, val, p, s, ans; 
                init(); 
                ks[kn] 
            = n+1
                
            for(i = 0; i < kn; i++){
                    has[i] 
            = true
                    val 
            = ks[i+1]-ks[i]; 
                    pos[i] 
            = qn + i + 1
                    add(pos[i], val); 
                }
                printf(
            "Case %d:\n"++cnt);
                
            for(i = 0; i < qn; i++){
                    
            if(qs[i] == 'T'){
                        p 
            = lower_bound(ks, ks+kn, num[i]) - ks; 
                        has[p] 
            = false
                        val 
            = -1
                        add(pos[p], val); 
                        val 
            = 1
                        id[fr] 
            = num[i]; 
                        pos[p] 
            = fr--
                        add(pos[p], val); 
                    }
            else if(qs[i] == 'R'){
                        p 
            = find_k(num[i]); 
                        
            if(p <= qn){
                            ans 
            = id[p]; 
                        }
            else{
                            s 
            = sum(p-1); 
                            ans 
            = num[i] - s + ks[p - qn - 1- 1
                            
            if(!has[p - qn - 1]) ans++
                        }
                        printf(
            "%d\n", ans);
                    }
            else//'Q'
                        p = lower_bound(ks, ks+kn, num[i]) - ks; 
                        ans 
            = sum(pos[p] - 1); 
                        printf(
            "%d\n", ans + 1);
                    }
                }
            }
            int main(){
            #ifndef ONLINE_JUDGE
                freopen(
            "in.txt""r", stdin); 
                
            //freopen("out.txt", "w", stdout); 
            #endif 
                
            int t; 
                scanf(
            "%d"&t);
                
            while(t--){
                    input(); 
                    solve(); 
                }
                
            return 0;
            }





            posted on 2011-01-22 16:58 tw 閱讀(519) 評論(0)  編輯 收藏 引用 所屬分類: HDU題解

            <2025年8月>
            272829303112
            3456789
            10111213141516
            17181920212223
            24252627282930
            31123456

            導航

            統(tǒng)計

            常用鏈接

            留言簿

            文章分類

            文章檔案

            搜索

            最新評論

            亚洲午夜久久久影院伊人| 97久久超碰成人精品网站| 偷窥少妇久久久久久久久| 热re99久久精品国99热| 国产激情久久久久影院老熟女免费 | 亚洲国产天堂久久综合| 日韩精品久久久久久免费| 99久久亚洲综合精品成人| 久久人人爽人人人人片av| 精品久久久久久久久中文字幕| 精品久久久一二三区| 天天综合久久久网| 久久天堂AV综合合色蜜桃网| 久久99精品国产麻豆不卡| AV无码久久久久不卡蜜桃| 中文精品久久久久人妻不卡| 一本久久a久久精品综合香蕉| 久久久精品视频免费观看| 久久国产精品久久| 久久久久国产精品| 久久精品国产免费一区| 国产精品一区二区久久不卡| 老色鬼久久亚洲AV综合| 日韩久久久久久中文人妻| 亚洲午夜久久久影院伊人| 国内精品综合久久久40p| 一本一道久久a久久精品综合 | 久久91精品综合国产首页| a高清免费毛片久久| 久久精品男人影院| 中文精品久久久久国产网址| 国产精品99久久久久久董美香 | 伊人久久综合无码成人网| 久久午夜无码鲁丝片秋霞| 精品久久久久久国产 | 国产2021久久精品| 久久91这里精品国产2020| 亚洲七七久久精品中文国产| 久久久久久久久波多野高潮| 久久亚洲精品人成综合网| 99久久免费国产精品热|