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

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

Pku 3368 Frequent Values (線段樹)

 

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

#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個數所在新的分組中的編號

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) {

    
//如果所在組號相同,說明中間所有數都是一樣的,直接返回區間長度
    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以上,那么端點的兩個取最大,中間的區段用線段樹查詢最大值
    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 英雄哪里出來 閱讀(824) 評論(1)  編輯 收藏 引用 所屬分類: ACM

評論

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

話說我這題一直覺得線段樹的只是不知道該記錄什么。
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>
            久久久一二三| 免费不卡亚洲欧美| 国产欧美精品xxxx另类| 午夜精彩视频在线观看不卡| 久久激情综合网| 亚洲国产精品悠悠久久琪琪| 欧美精品在线一区| 亚洲一区二区黄| 裸体丰满少妇做受久久99精品| 亚洲精品久久嫩草网站秘色| 欧美日韩在线直播| 欧美一区二区三区日韩视频| 欧美sm视频| 亚洲一区制服诱惑| 影音欧美亚洲| 国产精品播放| 亚洲一区二区在线播放| 国产伦精品一区二区三区免费迷| 久久精品男女| 99日韩精品| 欧美xart系列在线观看| 亚洲一区二区三区四区在线观看| 国产一区三区三区| 欧美日韩另类丝袜其他| 久久精品国产久精国产一老狼 | 欧美日韩另类视频| 欧美一区二区精品久久911| 亚洲国产一区二区精品专区| 亚洲影院免费| 91久久久久久久久| 国产日韩欧美自拍| 欧美日韩一区在线播放| 久久久一区二区| 亚洲综合日韩在线| 亚洲精品日韩在线| 欧美大色视频| 久久免费视频在线观看| 亚洲一区在线看| 日韩午夜在线视频| 一区在线免费观看| 国产色综合天天综合网| 欧美日韩中文字幕日韩欧美| 久久亚洲综合色| 性色av一区二区三区在线观看 | 日韩亚洲欧美成人一区| 红桃视频一区| 国产日产亚洲精品系列| 欧美性猛交99久久久久99按摩| 老妇喷水一区二区三区| 久久国产欧美精品| 亚洲欧美一区在线| 制服丝袜亚洲播放| 99综合在线| 亚洲精品社区| 亚洲精品国产日韩| 欧美激情第4页| 欧美国产精品专区| 欧美大片免费观看在线观看网站推荐| 久久久国产精品一区| 欧美一区二区视频在线| 亚洲欧美怡红院| 狠狠综合久久av一区二区小说| 国产欧美日韩综合| 国产精品系列在线播放| 国产精品丝袜91| 国产精品日韩久久久久| 国产精品久久久免费| 国产精品美女www爽爽爽视频| 欧美视频日韩视频在线观看| 欧美日韩成人综合天天影院| 欧美日韩ab| 欧美日韩一区二区三区免费| 欧美午夜不卡影院在线观看完整版免费| 欧美高清一区二区| 欧美日韩国产经典色站一区二区三区| 欧美精品七区| 欧美色精品在线视频| 国产精品多人| 国产伦理一区| 激情五月***国产精品| 亚洲国产99| 99re66热这里只有精品4| 中文亚洲免费| 午夜久久99| 久久久综合精品| 欧美激情精品久久久久久大尺度| 亚洲国产91| av不卡在线| 亚洲欧美影院| 久久综合久色欧美综合狠狠 | 国产欧美日韩一区二区三区在线| 国产欧美一级| 亚洲二区在线视频| 一区二区国产在线观看| 午夜性色一区二区三区免费视频 | 免费亚洲婷婷| 欧美日韩视频在线第一区| 国产精品久久久久影院色老大| 国产婷婷色一区二区三区| 伊人夜夜躁av伊人久久| 日韩一级在线| 久久精品男女| 亚洲高清不卡av| 亚洲午夜免费视频| 久久午夜精品| 国产精品www994| 精品动漫3d一区二区三区| 99热这里只有精品8| 久久精品国产精品亚洲| 亚洲国产精品久久久久秋霞影院 | 亚洲午夜激情在线| 久久综合图片| 亚洲性感激情| 欧美成人精品在线视频| 国产欧美一区二区精品仙草咪| 在线欧美日韩精品| 午夜电影亚洲| 亚洲国产精品黑人久久久| 午夜精品久久久久久| 欧美激情亚洲另类| 狠狠久久五月精品中文字幕| 一区二区成人精品| 欧美成人中文字幕| 亚洲欧美中文日韩v在线观看| 欧美高清在线播放| 怡红院精品视频| 久久xxxx精品视频| 9色精品在线| 欧美fxxxxxx另类| 激情欧美一区二区三区在线观看| 亚洲一区二区三区中文字幕| 欧美韩国日本一区| 久久精品二区| 国产精品系列在线| 亚洲一二三级电影| 最新国产拍偷乱拍精品| 久久久久在线| 国际精品欧美精品| 欧美在线观看视频一区二区| 在线视频你懂得一区| 美乳少妇欧美精品| 在线精品国产成人综合| 久久久久久久久久久一区 | 欧美国产精品劲爆| 久久人人爽人人爽爽久久| 国产精品五区| 午夜电影亚洲| 亚洲香蕉网站| 国产精品豆花视频| 亚洲综合999| 中日韩高清电影网| 国产精品久久7| 亚洲女性裸体视频| 麻豆成人91精品二区三区| 午夜精品一区二区三区电影天堂| 国产精品mv在线观看| 一级成人国产| 日韩亚洲一区二区| 欧美日韩一区不卡| 亚洲在线不卡| 亚洲综合电影| 国产麻豆日韩欧美久久| 久久精品99久久香蕉国产色戒 | 久久黄色影院| 一区在线视频观看| 免费一区视频| 欧美成人国产va精品日本一级| 亚洲激情女人| 亚洲麻豆视频| 国产精品qvod| 久久久久国产精品一区| 久久美女艺术照精彩视频福利播放| 国色天香一区二区| 欧美3dxxxxhd| 欧美日韩大片| 午夜欧美精品| 久久久久久久久久久久久9999| 在线观看视频一区二区| 亚洲青涩在线| 国产精品推荐精品| 另类亚洲自拍| 欧美日韩精品久久久| 午夜国产精品视频免费体验区| 欧美一区二区三区免费在线看| 禁久久精品乱码| 亚洲精品久久久久久下一站 | 国产精品视频第一区| 久久九九国产| 欧美激情影音先锋| 欧美一区成人| 男女激情视频一区| 亚洲一区在线观看视频 | 国产一二三精品| 欧美激情一区二区三区蜜桃视频 | 亚洲欧洲久久| 国产精品资源在线观看| 欧美国产日本| 国产精品毛片在线| 欧美高潮视频| 国产精品日韩精品欧美精品|