• <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ù)組實(shí)現(xiàn)求和和查詢第k個(gè)元素的功能
            #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 閱讀(505) 評(píng)論(0)  編輯 收藏 引用 所屬分類: HDU題解

            <2025年5月>
            27282930123
            45678910
            11121314151617
            18192021222324
            25262728293031
            1234567

            導(dǎo)航

            統(tǒng)計(jì)

            常用鏈接

            留言簿

            文章分類

            文章檔案

            搜索

            最新評(píng)論

            亚洲色欲久久久综合网| 亚洲伊人久久成综合人影院 | 色婷婷综合久久久久中文字幕| 精品水蜜桃久久久久久久| 午夜精品久久影院蜜桃| 狼狼综合久久久久综合网| 香蕉久久一区二区不卡无毒影院 | 亚洲伊人久久大香线蕉综合图片| 无码人妻精品一区二区三区久久久| 国产精品久久久久jk制服| 久久精品成人免费观看97| 亚洲综合日韩久久成人AV| 久久免费视频6| 国产欧美一区二区久久| 久久久国产打桩机| 久久久久久噜噜精品免费直播 | 国产精品狼人久久久久影院 | 国产精品伊人久久伊人电影| 97精品依人久久久大香线蕉97| 久久精品国产精品亜洲毛片| WWW婷婷AV久久久影片| 777午夜精品久久av蜜臀| 亚洲人成无码久久电影网站| 99热热久久这里只有精品68| 精品国产一区二区三区久久久狼| 国内精品伊人久久久影院| 久久久91人妻无码精品蜜桃HD | 久久国产精品久久国产精品| 影音先锋女人AV鲁色资源网久久| 国产高清美女一级a毛片久久w| 国产91色综合久久免费| 久久99国产精品尤物| 国产精品无码久久久久久| 人妻少妇久久中文字幕| 久久精品国产亚洲av水果派 | 免费精品久久久久久中文字幕| 91久久精品视频| 久久午夜综合久久| 青青草原综合久久大伊人导航| 亚洲国产成人久久综合一区77| 色婷婷综合久久久久中文字幕 |