• <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(數據結構)

            //用樹狀數組實現求和和查詢第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 閱讀(513) 評論(0)  編輯 收藏 引用 所屬分類: HDU題解

            <2025年6月>
            25262728293031
            1234567
            891011121314
            15161718192021
            22232425262728
            293012345

            導航

            統計

            常用鏈接

            留言簿

            文章分類

            文章檔案

            搜索

            最新評論

            国产日韩欧美久久| 久久久久99精品成人片直播| 99久久er这里只有精品18| 国产精品9999久久久久| 久久久久无码精品国产不卡| 亚洲乱亚洲乱淫久久| 亚洲欧美精品一区久久中文字幕| 91麻豆国产精品91久久久| 成人久久免费网站| 久久九九亚洲精品| 亚洲国产精品嫩草影院久久| 国产亚洲精品自在久久| 久久久99精品成人片中文字幕| 久久午夜无码鲁丝片午夜精品| 久久天天躁夜夜躁狠狠躁2022| …久久精品99久久香蕉国产| 久久99亚洲综合精品首页| 伊人久久无码中文字幕| 91精品国产综合久久香蕉 | 久久久久亚洲精品男人的天堂 | 国产69精品久久久久9999APGF| 99久久成人国产精品免费| 伊人久久成人成综合网222| 精品一区二区久久| 亚洲综合精品香蕉久久网| 久久精品国产亚洲AV不卡| 狠狠色丁香久久婷婷综合五月| 伊人情人综合成人久久网小说| 国产精品久久久久天天影视| 免费无码国产欧美久久18| 精品无码久久久久久国产| 国产精品一久久香蕉国产线看观看| 少妇久久久久久被弄到高潮 | 亚洲精品国产成人99久久| 国产成人久久精品区一区二区| 亚洲av成人无码久久精品| 亚洲精品第一综合99久久| 欧美久久久久久午夜精品| 99久久伊人精品综合观看| 一本久久久久久久| 久久国产精品-国产精品|