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

隨筆 - 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>
            欧美成人综合网站| 亚洲国产天堂久久综合| 亚洲永久精品国产| 欧美有码在线观看视频| 国产精品久久久久影院色老大 | 亚洲图片欧美日产| 午夜视频精品| 国产一区二区精品久久99| 久久久精品2019中文字幕神马| 暖暖成人免费视频| 一区二区av在线| 国产精品美女久久久久av超清| 午夜精品免费视频| 欧美69视频| 亚洲视频精品| 韩日精品在线| 欧美精品尤物在线| 午夜免费日韩视频| 亚洲二区免费| 亚洲欧美中文日韩v在线观看| 国内外成人免费视频| 欧美电影免费观看高清完整版| 一区二区三区欧美在线| 久久久噜噜噜久噜久久| 日韩午夜激情电影| 国内外成人在线| 欧美日韩黄色大片| 久久久夜夜夜| 国产精品99久久久久久久久| 蜜桃av噜噜一区| 亚洲欧美中文字幕| 亚洲人体影院| 国产亚洲综合性久久久影院| 欧美日本网站| 久久综合色天天久久综合图片| 一区电影在线观看| 欧美国产精品一区| 久久国产日韩| 亚洲一区二区三区777| 在线成人小视频| 国产精品乱子乱xxxx| 久久夜色精品国产噜噜av| 亚洲视频大全| 亚洲精品国产精品国自产观看浪潮 | 欧美二区视频| 亚欧成人精品| 亚洲网站在线观看| 亚洲精品一区在线观看香蕉| 欧美 日韩 国产精品免费观看| 先锋影音网一区二区| 亚洲毛片在线免费观看| 在线精品亚洲| 黑人操亚洲美女惩罚| 国产精品九色蝌蚪自拍| 欧美久久婷婷综合色| 久久影视精品| 久久久久久久久岛国免费| 亚洲欧美国产日韩中文字幕 | 一区二区高清视频| 91久久线看在观草草青青| 久久综合影视| 噜噜噜91成人网| 久久精品国产一区二区三| 亚洲欧美日韩另类| 亚洲主播在线观看| 亚洲一二三区视频在线观看| 一区二区三区高清在线| 99视频超级精品| 日韩视频永久免费观看| 亚洲精品国产品国语在线app| 亚洲第一主播视频| 亚洲第一视频网站| 亚洲国产裸拍裸体视频在线观看乱了中文| 国产最新精品精品你懂的| 国产日韩欧美高清| 国产一区二区观看| 黄色成人av在线| 在线观看欧美黄色| 亚洲国产一成人久久精品| 亚洲第一黄色| 亚洲日本成人| 在线视频免费在线观看一区二区| 亚洲最新视频在线播放| 亚洲午夜精品一区二区| 午夜国产一区| 久久精品视频免费| 免费观看不卡av| 亚洲国产另类久久久精品极度| 欧美电影在线免费观看网站| 亚洲国产一区二区三区高清| 亚洲精品免费在线| 中日韩男男gay无套| 亚洲女人天堂成人av在线| 欧美在线关看| 欧美成人精品h版在线观看| 欧美久久视频| 国产精品视频免费| 精品动漫3d一区二区三区免费| 亚洲国产精品热久久| 99re6这里只有精品视频在线观看| 中文精品视频一区二区在线观看| 午夜伦理片一区| 美腿丝袜亚洲色图| 日韩视频在线一区二区| 欧美一级专区免费大片| 免费欧美电影| 国产精品欧美在线| 亚洲电影免费在线观看| 亚洲视屏一区| 久久男人av资源网站| 亚洲日本中文字幕区| 亚洲欧美综合精品久久成人 | 美女被久久久| 欧美视频在线播放| 激情综合视频| 亚洲在线观看| 欧美福利视频网站| 亚洲欧美大片| 欧美激情亚洲精品| 国产亚洲一区二区三区在线播放 | 亚洲精品美女| 久久大香伊蕉在人线观看热2| 欧美激情第二页| 国产主播精品在线| 一区二区三区三区在线| 久久综合伊人77777| 一本大道av伊人久久综合| 久久男人av资源网站| 国产精品免费观看视频| 亚洲美女中文字幕| 免费看亚洲片| 亚洲欧美一区二区原创| 欧美日韩一级黄| 亚洲国产欧美不卡在线观看| 欧美中文字幕视频| 99综合电影在线视频| 欧美 日韩 国产 一区| 含羞草久久爱69一区| 亚洲欧美国产77777| 亚洲精品久久| 美女主播一区| 伊人久久久大香线蕉综合直播 | 欧美成人亚洲| 一区在线播放| 久久成人亚洲| 亚洲亚洲精品在线观看| 欧美日韩国产综合新一区| 亚洲国产视频a| 美国十次成人| 久久久久国产精品一区二区| 国产精品日日摸夜夜添夜夜av| 一区二区三区日韩精品| 亚洲人成网站精品片在线观看| 久久亚洲捆绑美女| 精品成人在线| 裸体丰满少妇做受久久99精品 | 久久久久久久久蜜桃| 国产日韩精品一区二区浪潮av| 亚洲一级在线| 99国产精品久久久久久久| 欧美另类一区二区三区| 99re8这里有精品热视频免费| 亚洲国产精品成人精品| 欧美成人r级一区二区三区| 亚洲国产精品福利| 亚洲电影下载| 欧美黑人一区二区三区| 日韩亚洲欧美一区| 日韩视频在线一区| 国产精品盗摄久久久| 香蕉成人啪国产精品视频综合网| 亚洲永久在线| 国产亚洲精品v| 久久综合狠狠综合久久综合88| 久久久av网站| 亚洲精品欧美日韩| 亚洲毛片av| 国产精品入口福利| 久久男人av资源网站| 开心色5月久久精品| 亚洲美女尤物影院| 夜夜嗨av一区二区三区中文字幕 | 亚洲在线免费观看| 国产婷婷一区二区| 模特精品在线| 欧美女激情福利| 亚洲男人天堂2024| 欧美综合国产精品久久丁香| 在线欧美一区| 亚洲国产视频一区| 国产精品久久一区主播| 久久在线免费| 欧美激情免费观看| 午夜伦理片一区| 久久综合久久综合九色| 夜夜嗨av一区二区三区中文字幕| 亚洲一区二区在线观看视频| 狠色狠色综合久久| 亚洲精品网址在线观看| 国产九九精品视频|