青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

隨筆 - 97, 文章 - 22, 評論 - 81, 引用 - 0
數據加載中……

PKU 2761 Feed the dogs

題目鏈接:http://poj.org/problem?id=2761
/*
題意:
    給出一個長度為N(N <= 100000)的數列,然后是一連串詢問,詢問數
<= 50000,詢問的格式是a, b, k,問[a, b]區間中的k小數。

解法:
二分+樹狀數組 或者 二分+歸并樹+線段樹

思路:
    這題的解法比較多,可以練習各種數據結構,不知是不是我的線段樹
效率比較低,用線段樹一直過不去,這題和PKU 2104有個區別就是給定的
詢問區間不會互相包含,于是就可以用樹狀數組求解,雖然復雜度很接近
,但是樹狀數組的常數小得多。
    來看看具體的解法:首先將讀進來的N個數離散化,可以用二分或者
hash或者先排序一遍記錄下標皆可。然后讀入的M個區間詢問進行對X軸遞
增排序,注意需要記錄下當前詢問的下標,以便之后輸出答案。對于讀入
的M個區間進行線性掃描,對第一個區間[x0,y0]中的所有數插入到樹狀數
組中,即調用add(val, 1),其x0 <= val <= y0,然后二分查找第k大數,
這個復雜度是O(logNlogN)的,對于下一個區間[x1,y1],如果這兩個區間
有相交部分,那么顯然這部分不用操作,我們知道對,[x0,y0]中有但
[x1,y1]中沒有的部分進行刪除操作,即調用add(val, -1),而對[x1,y1]
中有但[x0,y0]中沒有的部分進行添加操作,即調用add(val, 1)。每次添
加完畢后進行統計。最后輸出答案即可。注意輸出的時候要小心,下標之
間的映射。
*/


#include 
<iostream>
#include 
<algorithm>
using namespace std;

#define maxn 100010

struct Value {
    
int val;
    
int idx;
}
V[maxn];

struct Intval {
    
int l, r, k;
    
int idx;
}
I[maxn];
int ID[maxn];

struct TreeArray {
    
int data[maxn];
    
int MaxVal;

    
void setMaxVal(int _v) {
        MaxVal 
= _v;
    }

    
void clear() {
        MaxVal 
= maxn - 1;
        
for(int i = 1; i < maxn; i++{
            data[i] 
= 0;
        }

    }

    
int lowbit(int x) {
        
return x & (-x);
    }


    
void add(int pos, int val) {
        
while(pos && pos <= MaxVal) {
            data[pos] 
+= val;
            pos 
+= lowbit(pos);
        }
 
    }


    
int  sum(int pos) 
        
int s = 0
        
while(pos >= 1{
            s 
+= data[pos]; 
            pos 
-= lowbit(pos);
        }
 
        
return s; 
    }


    
int Query(int K) {
        
int l = 1;
        
int h = MaxVal;
        
int ans = 0;
        
while(l <= h) {
            
int m = (l + h) >> 1;
            
if(sum(m-1< K) {
                l 
= m + 1;
                
if(m > ans)
                    ans 
= m;
            }
else
                h 
= m - 1;
        }

        
return ans;
    }

}
;

int n, m;
bool cmp0(Value a, Value b) {
    
return a.val < b.val;
}

bool cmp1(Intval a, Intval b) {
    
return a.l < b.l;
}


TreeArray Tree;
int ans[ maxn ];

int Min(int a, int b) {
    
return a < b ? a : b;
}

int Max(int a, int b) {
    
return a > b ? a : b;
}

int main() {
    
int i, j;
    
while(scanf("%d %d"&n, &m) != EOF) {
        
for(i = 1; i <= n; i++{
            scanf(
"%d"&V[i].val);
            V[i].idx 
= i;
        }

        sort(V
+1, V+n+1, cmp0);
        
for(i = 1; i <= n; i++{
            ID[V[i].idx] 
= i;
        }


        
for(i = 1; i <= m; i++{
            scanf(
"%d %d %d"&I[i].l, &I[i].r, &I[i].k);
            
if(I[i].l > I[i].r) {
                swap(I[i].l, I[i].r);
            }

            I[i].idx 
= i;
        }

        sort(I
+1, I+m+1, cmp1);

        Tree.clear();
        Tree.setMaxVal(n);
        I[
0].l = I[0].r = 0;

        
for(i = 1; i <= m; i++{
            
int MinSub = Min(I[i-1].r, I[i].l-1);
            
// 將上一個區間剩余的數去掉
            for(j = I[i-1].l; j <= MinSub; j++{
                Tree.add(ID[j], 
-1);
            }
            
            
for(j = I[i].r+1; j <= I[i-1].r; j++{
                Tree.add(ID[j], 
-1);
            }


            
// 加入這個區間新增的數
            int MaxAdd = Max(I[i-1].r+1, I[i].l);
            
for(j = MaxAdd; j <= I[i].r; j++{
                Tree.add(ID[j], 
1);
            }


            ans[ I[i].idx ] 
= V[ Tree.Query(I[i].k) ].val;
        }


        
for(i = 1; i <= m; i++{
            printf(
"%d\n", ans[i]);
        }

    }

    
return 0;
}


/*
7 6
1 5 2 2 2 7 4
2 7 1
2 7 2
2 7 3
2 7 4
2 7 5
2 7 6

*/

posted on 2011-04-03 10:28 英雄哪里出來 閱讀(1258) 評論(0)  編輯 收藏 引用 所屬分類: 線段樹樹狀數組

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            国产精品美女999| 亚洲美女啪啪| 日韩视频免费观看| 一区二区三区在线免费视频| 久久精品国产一区二区三区| 尤物在线精品| 国产一区二区高清| 暖暖成人免费视频| 牛人盗摄一区二区三区视频| 亚洲一区观看| 久久免费高清| 免费欧美在线| 久久精品亚洲乱码伦伦中文 | 国产精品av久久久久久麻豆网| 欧美在线观看天堂一区二区三区| 午夜精品影院在线观看| 久久精品一区二区三区不卡| 亚洲精品乱码久久久久久蜜桃91| 精品999网站| 韩国三级在线一区| 欧美精品一区二区三区蜜桃 | 中国成人亚色综合网站| 亚洲欧美日韩国产综合在线| 亚洲日本精品国产第一区| 国产日韩在线看片| 亚洲电影观看| 亚洲国产精品精华液网站| 夜夜嗨av一区二区三区四区| 亚洲精品欧美一区二区三区| 在线观看视频一区二区欧美日韩| 亚洲精品日韩一| 亚洲精品乱码久久久久久日本蜜臀| 久久久蜜桃一区二区人| 欧美日韩 国产精品| 欧美a级片网| 久久久久欧美| 免费永久网站黄欧美| 免费成人av在线看| 欧美韩日精品| 亚洲在线视频观看| 一区二区三区偷拍| 免费不卡在线视频| 欧美日韩国产系列| …久久精品99久久香蕉国产| 亚洲黄色在线看| 久久蜜桃资源一区二区老牛 | 国产综合精品| 夜夜躁日日躁狠狠久久88av| 99re亚洲国产精品| 亚洲欧美国产va在线影院| 亚洲激情电影中文字幕| 亚洲高清自拍| 亚洲欧美综合v| 久久国产精品亚洲va麻豆| 久久综合给合久久狠狠色| 亚洲精品欧洲| 亚洲欧美激情四射在线日| 亚洲激情亚洲| 亚洲欧美日韩精品在线| 欧美激情一区在线| 国产日韩在线一区| 99re亚洲国产精品| 夜夜嗨av色综合久久久综合网| 亚洲在线播放| 久久经典综合| 依依成人综合视频| 亚洲视频福利| 在线播放亚洲| 亚洲视频自拍偷拍| 乱中年女人伦av一区二区| 久久99在线观看| 久久视频精品在线| 欧美日韩一二三区| 亚洲伊人一本大道中文字幕| 蜜臀av国产精品久久久久| 午夜精品成人在线视频| 欧美日韩免费在线| 在线国产日韩| 亚洲国产第一页| 欧美一区二区三区免费看| 国产精品入口尤物| 亚洲精品一品区二品区三品区| 性欧美xxxx视频在线观看| 99精品视频一区| 美日韩在线观看| 国产午夜精品理论片a级大结局| 久久se精品一区精品二区| 亚洲黄色在线视频| 久久综合中文字幕| 一本色道久久88综合亚洲精品ⅰ| 可以免费看不卡的av网站| 欧美成人乱码一区二区三区| 国产一区二区三区av电影| 欧美一区二区女人| 欧美xx视频| 亚洲大片av| 国产一区二区精品久久91| 香蕉久久夜色| 一本久久综合亚洲鲁鲁| 国产亚洲午夜| 久久高清国产| 亚洲欧洲另类国产综合| 国产精品毛片在线看| 亚洲女性裸体视频| 一本色道久久综合亚洲精品婷婷| 免费成人毛片| 久久精品亚洲精品| 日韩午夜电影| 亚洲三级视频在线观看| 国产精品一区在线观看| 欧美亚洲综合久久| 亚洲一区免费| 日韩亚洲精品在线| 亚洲精品国精品久久99热| 亚洲精品欧美日韩| 狠狠色香婷婷久久亚洲精品| 久久视频在线视频| 欧美亚男人的天堂| 欧美专区日韩专区| 久久久久久国产精品mv| 欧美一区二区在线看| 欧美一级成年大片在线观看| 国产模特精品视频久久久久| 久久人人爽人人爽| 开心色5月久久精品| 久久久久久亚洲精品杨幂换脸| 久久精品视频在线观看| 国产精品ⅴa在线观看h| 亚洲黄网站黄| 国产日韩av一区二区| 91久久在线播放| 国产麻豆精品视频| 女仆av观看一区| 在线观看精品视频| 99精品久久久| 亚洲自拍偷拍麻豆| 午夜精品www| 国产午夜精品一区二区三区视频| 亚洲午夜影视影院在线观看| 黑人巨大精品欧美黑白配亚洲| 午夜精品免费视频| 亚洲国产精品ⅴa在线观看| 日韩视频精品在线| 亚洲一区影院| 久久亚洲欧美国产精品乐播| 久久av在线看| 欧美精品情趣视频| 久久精品99无色码中文字幕 | 校园春色国产精品| 亚洲三级观看| 亚洲精品少妇30p| av成人免费| 久久国产精品电影| 麻豆精品在线播放| 国产精品日韩欧美一区二区| 亚洲综合国产激情另类一区| 日韩亚洲国产欧美| 亚洲一区亚洲| 乱码第一页成人| 国产精品v片在线观看不卡| 亚洲天堂成人| 99精品欧美一区二区三区| 亚洲成在人线av| 99精品视频网| 女人色偷偷aa久久天堂| 亚洲黄一区二区三区| 亚洲人成7777| 久久久精品国产免大香伊| 亚洲伊人网站| 欧美日韩精品在线视频| 亚洲欧美日韩在线综合| 亚洲一卡二卡三卡四卡五卡| 亚洲精品乱码久久久久久| 亚洲精品久久久一区二区三区| 久久久久久九九九九| 在线亚洲国产精品网站| 夜夜爽av福利精品导航 | 欧美在线高清| 欧美制服丝袜| 99伊人成综合| 欧美精品123区| 香港久久久电影| 久久精品视频99| 一本综合精品| 欧美日韩一区二区三区免费看 | 亚洲美女在线一区| 亚洲国产欧美一区| 国产精品高潮呻吟久久av无限| 亚洲精品欧美| 国产精品一区二区久激情瑜伽| 麻豆久久久9性大片| 亚洲国产成人av在线| 久久成人国产精品| 亚洲成色www久久网站| 久久大逼视频| 亚洲欧洲日本一区二区三区| 日韩视频中午一区| 尤物在线观看一区| 欧美国产激情二区三区| 久久精品国产欧美亚洲人人爽|