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

隨筆 - 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 英雄哪里出來 閱讀(820) 評論(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| 亚洲一卡久久| 老司机免费视频一区二区| 国产欧美一区二区在线观看| 一二三区精品福利视频| 亚洲在线视频| 红桃视频国产一区| 91久久精品日日躁夜夜躁欧美 | 国产精品s色| 午夜久久黄色| 久久精品日韩| 亚洲综合另类| 激情综合自拍| 国产精品乱码一区二区三区| 欧美插天视频在线播放| 欧美专区福利在线| 亚洲字幕一区二区| 亚洲精品一级| 国产自产2019最新不卡| 欧美成人视屏| 亚洲欧洲久久| 欧美一区二区成人| 亚洲尤物视频在线| 久久高清一区| 欧美电影免费观看网站| 欧美激情一区二区三区| 欧美日一区二区在线观看| 欧美日韩国产在线播放网站| 男女视频一区二区| 国产精品国产三级欧美二区 | 国产精品拍天天在线| 另类亚洲自拍| 国产欧美在线看| 亚洲欧洲99久久| 91久久极品少妇xxxxⅹ软件| 欧美精品v日韩精品v韩国精品v| 欧美高清视频www夜色资源网| 亚洲第一久久影院| 久久久久久网| 久久只精品国产| 欧美一级片在线播放| 噜噜噜噜噜久久久久久91| 一区二区三区久久久| 欧美精品videossex性护士| 影音先锋久久精品| 麻豆九一精品爱看视频在线观看免费| 亚洲电影免费在线| 久久中文字幕一区二区三区| 国产精品入口福利| 欧美在线高清视频| 亚洲欧美在线一区| 国产在线高清精品| 男女av一区三区二区色多| 欧美日韩免费观看一区三区| 亚洲欧美另类国产| 国产美女一区二区| 久久精品综合网| 亚洲欧美电影院| 亚洲电影免费观看高清完整版在线观看| 久久精品国内一区二区三区| 久久手机免费观看| 亚洲欧洲另类国产综合| av成人手机在线| 激情欧美一区| 一区二区三区免费观看| 国产亚洲午夜高清国产拍精品| 久久狠狠一本精品综合网| 亚洲精品在线观| 久久久精品性| 亚洲精品一区二区在线观看| 欧美精品一区在线| aⅴ色国产欧美| 中国av一区| 亚洲福利久久| 亚洲一区二区在| 一区二区毛片| 欧美日韩一区二区三区高清| 中日韩高清电影网| 亚洲欧美电影在线观看| 久久久久中文| 久久九九全国免费精品观看| 欧美视频国产精品| 亚洲人成在线观看网站高清| 国产亚洲一区二区在线观看 | 久久久人成影片一区二区三区观看| 狠狠色香婷婷久久亚洲精品| 亚洲经典在线| 亚洲午夜激情| 国产精品嫩草影院一区二区| 亚洲视频在线观看视频| 亚洲综合精品一区二区| 国产一区二区三区久久 | 久久综合伊人77777尤物| 久久久久久97三级| 亚洲国产精品成人精品| 欧美久久成人| 亚洲欧美日韩综合| 欧美国产日韩精品免费观看| 一区二区三区在线观看欧美| 欧美亚洲综合在线| 欧美精品色一区二区三区| 亚洲国产精品悠悠久久琪琪| aa成人免费视频| 在线播放豆国产99亚洲| 欧美日韩日本国产亚洲在线| 亚洲精品欧美激情| 欧美中文日韩| 99re国产精品| 国产亚洲一区二区三区| 欧美成ee人免费视频| 欧美在线观看一二区| 中国亚洲黄色| 欧美激情按摩在线| 激情婷婷亚洲| 国产精品v欧美精品v日韩精品 | 国产毛片一区二区| 欧美激情精品久久久久久蜜臀 | 国产精品国产福利国产秒拍| 欧美一区二区三区视频免费播放 | 久久国产精品久久久| 亚洲三级免费| 99精品视频一区| 亚洲精品一区在线观看| 亚洲精品裸体| 欧美一区二区性| 久久久久久久久一区二区| 久久超碰97中文字幕| 欧美亚洲在线播放| 亚洲自拍偷拍色片视频| 午夜精品久久一牛影视| 亚洲人成小说网站色在线| 久久久久久久综合狠狠综合| 性8sex亚洲区入口| 欧美激情久久久久| 国产精品理论片在线观看| 国产亚洲一级| 日韩视频不卡| 久久久久久亚洲精品中文字幕| 久久综合一区二区三区| 欧美四级电影网站| 国内精品免费在线观看| 国产一二三精品| 一区二区三区蜜桃网| 欧美在线视屏 | 国产精品乱码妇女bbbb| 一色屋精品亚洲香蕉网站| 一区二区三区偷拍| 欧美99在线视频观看| 亚洲一区精彩视频| 国产精品丝袜xxxxxxx| 亚洲高清影视| 欧美一区二区三区免费在线看| 久久综合伊人77777蜜臀| 99在线热播精品免费99热| 久久免费视频观看| 国产一区二区三区免费不卡| 亚洲免费电影在线| 久久综合网色—综合色88| 99re66热这里只有精品4| 久久久久久夜精品精品免费| 国产精品一区二区在线观看不卡 | 欧美jizz19性欧美| 国产亚洲欧洲997久久综合| 亚洲网站啪啪| 日韩一区二区精品葵司在线| 免费在线国产精品| 一区二区欧美激情| 99热这里只有成人精品国产| 亚洲精品一区二区三| 亚洲欧美激情视频| 国产精品久久一区二区三区| 欧美在线视频不卡| 久久噜噜噜精品国产亚洲综合| 亚洲国产日韩欧美在线99 | 国产午夜精品一区二区三区欧美| 亚洲视频每日更新| 亚洲精品一区二区网址| 一区二区三区日韩欧美| 国产视频精品va久久久久久| 鲁鲁狠狠狠7777一区二区| 麻豆精品视频在线| 亚洲欧美春色| 欧美不卡一卡二卡免费版| 欧美在线一二三四区| 欧美日韩一区在线观看| 老司机一区二区三区| 国产精品国产一区二区| 久久综合狠狠| 欧美日韩国产综合网| 亚洲大片在线| 亚洲国产欧美在线| 亚洲欧美成人精品| 亚洲综合欧美| 国产精品视频大全| 欧美主播一区二区三区美女 久久精品人 | 99视频日韩| 欧美国产成人精品| 毛片一区二区三区| 国产一区二区三区久久久| 亚洲一二三四区|