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

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

Pku 3368 Frequent Values (線段樹)

 

/*
上金工實習(xí),無聊,找到題目想想吧,那就pku 3368吧,一直想做掉卻一直沒想法,題目意思很明確,
給定一串序列,然后是m條詢問,問[a, b]區(qū)間之間出現(xiàn)的數(shù)字頻率最多的是哪個數(shù),由于m很大,所以
詢問的復(fù)雜度必須要是log(n),這樣一來就先確定下來是線段樹了,但是以前沒深入想下去,
重新看了遍題目,然后到了8教就開始想,突然就有思路了,主要是以前有個限制條件沒看見,
有了這個限制條件題目就變得簡單了。就是這句話in non-decreasing order,所有的數(shù)非遞減排列。
換言之,就是說如果兩個數(shù)相同的話,他們必定生活在以前,并且中間的數(shù)和他們也相同。
于是就有了nlog(n)的算法:
對于所有的數(shù)均設(shè)定一個組號,也可以叫離散化吧,相同的數(shù)有相同的組號,然后將各個數(shù)的頻率統(tǒng)計后
記錄在一個數(shù)組中,表示該類數(shù)的大小,然后對于輸入的詢問[x, y],直接查詢它們在哪個組,分三種情況
1. 如果x和y在一個組,那么最長長度就是y - x + 1
2. 如果組號相差1,那么找出兩者的分界點z(假設(shè)z點和x點組號相同),那么答案就是Max{z - x + 1, y - z}
3. 如果相差大于1,那么先將兩頭截掉,統(tǒng)計大的記錄,再和中間那段的最大值比較大小,中間那段的最大值可以用線段樹區(qū)間查詢最值
*/

#include 
<iostream>

using namespace std;

struct point {
    
int start;
    
int end;
    
int num;
    
int coun;
}
p[ 100010 ];

int ori[ 100010 ];
int n, T;
int Rhash[ 100010 ];      //第i個數(shù)所在新的分組中的編號

struct Seg {
    
int num;
    
int Count;
}
tree[1000010];

void init() {

    T 
= 1;
    p[
1].start = 0;
    p[
1].end = 0;
    p[
1].coun = 1;
    p[
1].num = ori[0];
    Rhash[ 
0 ] = 1;
    
int i;
    
for(i = 1; i < n; i++{
        
if(ori[i] == ori[i-1]) {
            p[ T ].coun 
++;
            p[ T ].end 
= i;
        }
else {
            T 
++;
            p[ T ].num 
= ori[i];
            p[ T ].coun 
= 1;
            p[ T ].start 
= i;
            p[ T ].end 
= i;
        }

        Rhash[ i ] 
= T;
    }


}


void Build(int P, int l, int r) {
    
int mid = (l + r) / 2;

    
if(l == r) {
        tree[P].Count 
= p[l].coun;
        tree[P].num 
= p[l].num;
        
return ;
    }

    Build(
2*P, l, mid);
    Build(
2*P+1, mid+1, r);

    
if(tree[2*P].Count > tree[2*P+1].Count) {
        tree[P] 
= tree[2*P];
    }
else
        tree[P] 
= tree[2*P+1];
}


int Query(int P, int a, int b, int l, int r) {
    
    
if(a == l && r == b) {
        
return tree[P].Count;
    }


    
int mid = (l + r) / 2;
    
if(b <= mid) {
        
return Query(2*P, a, b, l, mid);
    }
else if(mid + 1 <= a) {
        
return Query(2*P+1, a, b, mid+1, r);
    }
else {
        
int x = Query(2*P, a, mid, l, mid);
        
int y = Query(2*P+1, mid+1, b, mid+1, r);
        
return x > y ? x : y;
    }


}

int Solve(int x, int y) {

    
//如果所在組號相同,說明中間所有數(shù)都是一樣的,直接返回區(qū)間長度
    if(Rhash[x] == Rhash[y]) {
        
return y - x + 1;
    }

    
//如果組號相差1,說明中間必定由一個分段點,將[x, y]線段分成兩段,去大的
    else if(Rhash[x] + 1 == Rhash[y]) {
        
int l = p[ Rhash[x] ].end - x + 1;
        
int r = y - p[ Rhash[y] ].start + 1;
        
return l > r ? l : r;
    }

    
//如果組號相差1以上,那么端點的兩個取最大,中間的區(qū)段用線段樹查詢最大值
    else {

        
int l = p[ Rhash[x] ].end - x + 1;
        
int r = y - p[ Rhash[y] ].start + 1;
        
int Max = l > r ? l : r;

        
int ans = Query(1, Rhash[x] + 1, Rhash[y] - 11, T);
        
return Max > ans ? Max : ans;
    }

}


int main() {
    
int i;
    
int q, x, y;
    
while(scanf("%d"&n) != EOF && n) {
        scanf(
"%d"&q);
        
for(i = 0; i < n; i++{
            scanf(
"%d"&ori[i]);
        }

        init();
        Build(
11, T);
        
while(q--{
            scanf(
"%d %d"&x, &y);
            x 
--; y --;
            printf(
"%d\n", Solve(x, y) );
        }

    }

    
return 0;
}

posted on 2009-04-07 13:42 英雄哪里出來 閱讀(820) 評論(1)  編輯 收藏 引用 所屬分類: ACM

評論

# re: Pku 3368 Frequent Values (線段樹)  回復(fù)  更多評論   

話說我這題一直覺得線段樹的只是不知道該記錄什么。
2009-06-29 11:06 | mr_moon
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲精品乱码久久久久久| 国产精品区免费视频| 久久嫩草精品久久久精品一| 永久域名在线精品| 国产视频自拍一区| 欧美视频在线观看视频极品| 美国成人直播| 欧美精品www在线观看| 欧美电影免费观看高清完整版| 欧美一区二区三区在| 欧美影院一区| 久久人人爽人人爽爽久久| 亚洲欧美在线网| 久久久国产91| 欧美日韩精品系列| 国产精品一区二区三区四区五区| 国产日韩欧美| 亚洲精品久久久久久一区二区 | 欧美视频一区二区三区在线观看| 老司机凹凸av亚洲导航| 欧美精彩视频一区二区三区| 欧美体内谢she精2性欧美| av成人免费在线观看| 欧美日韩中文字幕在线视频| 亚洲欧美日韩爽爽影院| 欧美一区二区精美| 亚洲高清网站| 欧美一级专区| 欧美日韩在线三区| 精品动漫3d一区二区三区免费| 亚洲激情在线观看视频免费| 亚洲欧美清纯在线制服| 亚洲第一免费播放区| 亚洲男人的天堂在线aⅴ视频| 乱人伦精品视频在线观看| 国产精品入口尤物| 亚洲一区二区精品视频| 欧美激情免费观看| 久久夜色精品国产欧美乱极品| 国产精品视频xxxx| 亚洲免费在线精品一区| 欧美成在线视频| 欧美大学生性色视频| 欧美日韩免费观看中文| 亚洲欧美精品一区| 亚洲欧洲一区| 亚洲国产欧美一区| 亚洲欧洲美洲综合色网| 久久综合久久综合这里只有精品 | 欧美福利视频在线观看| 在线成人亚洲| 久久本道综合色狠狠五月| 一区二区三区欧美激情| 欧美日韩亚洲一区在线观看| 亚洲免费视频在线观看| 午夜精品美女自拍福到在线| 国产精品一区视频| 免费在线看一区| 欧美国产日韩一区| 亚洲一级一区| 久久久久久久久久久久久女国产乱| 在线午夜精品自拍| 国产一区二区三区日韩| 亚洲精品欧美专区| 国产伦精品一区二区三区高清| 免费观看久久久4p| 欧美日韩不卡| 欧美国产视频日韩| 黄色在线一区| 亚洲欧美国产77777| 国产精品99久久不卡二区| 久久一二三四| 狂野欧美性猛交xxxx巴西| 国产精品伦一区| 欧美三级午夜理伦三级中文幕| 亚洲一区免费| 欧美区视频在线观看| 免费日韩av电影| 国产综合色产| 久久久久一区二区| 久久在线视频在线| 国产在线观看91精品一区| 亚洲一区在线免费| 亚洲一区二区成人| 国产精品色一区二区三区| 亚洲国产综合视频在线观看| 亚洲视频在线播放| 欧美在线观看一区| 在线精品福利| 欧美日韩精品一区二区| 一区二区欧美在线观看| 性欧美办公室18xxxxhd| 国产麻豆一精品一av一免费| 久久精选视频| 亚洲福利视频一区二区| 亚洲美女精品久久| 国产日韩成人精品| 欧美电影在线免费观看网站| 在线一区二区视频| 毛片基地黄久久久久久天堂| 99re国产精品| 极品尤物一区二区三区| 欧美激情一区二区| 性刺激综合网| 亚洲特级毛片| 亚洲精品中文字幕有码专区| 老司机精品视频网站| 欧美一区二区精品| 亚洲尤物在线| 亚洲精品一二区| 亚洲第一在线综合在线| 国产欧美视频一区二区三区| 欧美日韩激情小视频| 欧美精品一区在线播放| 另类图片国产| 久久久久久久久久码影片| 亚洲欧美日韩在线综合| 中国成人黄色视屏| 在线视频精品一| 亚洲永久在线| 欧美一区二区三区在线看| 亚洲欧美日本国产有色| 亚洲欧美福利一区二区| 欧美一区二区三区婷婷月色| 欧美资源在线| 久久手机免费观看| 久久久噜噜噜久久中文字幕色伊伊 | 亚洲韩国精品一区| 亚洲夫妻自拍| 亚洲婷婷在线| 久久野战av| 中国成人在线视频| 久久九九免费视频| 欧美日韩一区二区视频在线 | 国产精品久久久久9999吃药| 欧美日韩一区二区在线视频| 国产精品久久久久9999吃药| 狠狠色狠色综合曰曰| 亚洲作爱视频| 蜜臀av国产精品久久久久| 一本色道久久综合亚洲精品高清| 欧美一区二区高清| 欧美日韩精品系列| 亚洲欧洲精品一区二区三区| 亚洲一区黄色| 亚洲免费久久| 欧美日本在线| 亚洲精品一区二区三区樱花 | 夜夜爽99久久国产综合精品女不卡| 亚洲欧美成人一区二区三区| 亚洲国产高清自拍| 蜜桃av一区| 亚洲日韩欧美视频| 久久综合九色99| 久久国产精品久久久久久| 国产精品自在线| 久久久久国产一区二区三区四区| 日韩视频在线一区二区三区| 欧美精品在线观看91| 欧美成人中文字幕| 亚洲三级国产| 亚洲人成毛片在线播放| 欧美日本成人| 欧美一区二区三区视频在线 | 久久影院午夜片一区| 久久不射中文字幕| 禁断一区二区三区在线| 欧美好骚综合网| 欧美人在线视频| 久久免费偷拍视频| 欧美极品在线视频| 欧美在线影院| 欧美另类高清视频在线| 亚洲欧美国产另类| 久久综合伊人77777蜜臀| 亚洲精品视频中文字幕| 午夜精品美女久久久久av福利| 精品成人乱色一区二区| 一区二区三区视频在线看| 精品51国产黑色丝袜高跟鞋| 亚洲精品在线一区二区| 合欧美一区二区三区| 99香蕉国产精品偷在线观看| 在线播放一区| 久久久91精品国产一区二区精品| 日韩一二在线观看| 欧美成年人视频| 美女图片一区二区| 国产精品久久久爽爽爽麻豆色哟哟| 欧美不卡视频一区| 亚洲第一搞黄网站| 久久综合99re88久久爱| 久久这里只有精品视频首页| 国产亚洲午夜| 欧美一区午夜精品| 久久精品一本| 国内精品嫩模av私拍在线观看 | 亚洲靠逼com| 欧美亚洲不卡| 久久久久国内|