• <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 閱讀(505) 評論(0)  編輯 收藏 引用 所屬分類: HDU題解

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

            導航

            統計

            常用鏈接

            留言簿

            文章分類

            文章檔案

            搜索

            最新評論

            亚洲精品高清久久| 国产精品久久成人影院| 日产精品久久久久久久| 久久男人Av资源网站无码软件| 欧美喷潮久久久XXXXx| 国产99久久久久久免费看| 亚洲国产成人精品无码久久久久久综合| 亚洲精品NV久久久久久久久久| 国内精品伊人久久久久777| 久久国产精品一区二区| 久久久久久免费视频| 国产激情久久久久影院小草 | 国产韩国精品一区二区三区久久 | 一本色道久久综合狠狠躁篇| 久久亚洲私人国产精品| 久久久久一级精品亚洲国产成人综合AV区 | 久久精品国产亚洲AV不卡| 久久精品国产2020| 人妻丰满?V无码久久不卡| 久久综合久久综合久久| 男女久久久国产一区二区三区| 久久久久久国产精品免费免费| av无码久久久久久不卡网站| 亚洲午夜精品久久久久久浪潮 | 久久伊人影视| 久久精品免费一区二区三区| 日本五月天婷久久网站| 区亚洲欧美一级久久精品亚洲精品成人网久久久久 | 国产—久久香蕉国产线看观看| 久久婷婷成人综合色综合| 中文精品99久久国产 | 狠狠色噜噜色狠狠狠综合久久| 理论片午午伦夜理片久久 | 99精品伊人久久久大香线蕉| 国产精品岛国久久久久| 久久国产免费观看精品3| 亚洲七七久久精品中文国产| 欧美日韩精品久久久久| 亚洲人成无码网站久久99热国产| 韩国三级中文字幕hd久久精品| 成人a毛片久久免费播放|