• <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>

            gzwzm06

              C++博客 :: 首頁(yè) :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
              1 隨筆 :: 52 文章 :: 17 評(píng)論 :: 0 Trackbacks
              1#include <cstdio>
              2#include <cmath>
              3
              4const int SIZE = 100101;
              5
              6int arr[SIZE], N;
              7int cntFront[SIZE], cntBack[SIZE];
              8int Max[18][SIZE];
              9
             10inline int GetMax(const int& a, const int& b)
             11{
             12    return (a > b ? a : b);
             13}

             14
             15void Init()
             16{
             17    int i, cnt;
             18
             19    cntFront[1= 1;
             20    cnt = 1;
             21    for ( i = 2; i <= N; ++i )
             22    {
             23        if ( arr[i] != arr[i - 1] )
             24        {
             25            cnt = 1;
             26        }

             27        else {
             28            cnt++;
             29        }

             30        cntFront[i] = cnt;
             31    }

             32
             33    cntBack[N] = 1;
             34    cnt = 1;
             35    for ( i = N - 1; i > 0--i )
             36    {
             37        if ( arr[i] != arr[i + 1] )
             38        {
             39            cnt = 1;
             40        }

             41        else
             42        {
             43            cnt++;
             44        }

             45        cntBack[i] = cnt;
             46    }

             47}

             48
             49void MakeRMQ()
             50{
             51    int i, j;
             52
             53    for ( i = 1; i <= N; ++i )
             54    {
             55        Max[0][i] = cntFront[i];
             56    }

             57
             58    for ( j = 1; (1 << j) <= N; ++j )
             59        for ( i = 1; i + (1 << j) - 1 <= N; ++i )
             60        {
             61            Max[j][i] = GetMax( Max[j - 1][i], Max[j - 1][i + (1 << (j - 1))] );
             62        }

             63}

             64
             65inline int RMQ(const int& i, const int& j)
             66{
             67    int k = (int)(log((double)(j - i + 1)) / log(2.0));
             68
             69    return GetMax( Max[k][i], Max[k][j - (1 << k) + 1] ) ;
             70}

             71
             72int Query(int s, int e)
             73{
             74    if ( s == e )
             75        return 1;
             76    else 
             77    {
             78        int t, lv, rv;
             79
             80        lv = cntBack[s];
             81        rv = cntFront[e];
             82
             83        if ( s + lv - 1 > e - rv + 1 )
             84        {
             85            return (e - s + 1);
             86        }

             87
             88        t = GetMax( lv, rv );
             89
             90        s = s + lv;
             91        e = e - rv;
             92
             93        if ( s < e )
             94        {
             95            t = GetMax( t, RMQ( s, e ) );
             96        }

             97
             98        return t;
             99
            100    }

            101}

            102
            103int main()
            104{
            105//    freopen("1.txt", "r", stdin);
            106
            107    int i, s, e, Q;
            108
            109    while ( scanf("%d"&N) , N != 0 )
            110    {
            111        scanf("%d"&Q);
            112
            113        for ( i = 1; i <= N; ++i )
            114        {
            115            scanf("%d"&arr[i]);
            116        }

            117        
            118        Init();
            119        MakeRMQ();
            120
            121        for ( i = 0; i < Q; ++i )
            122        {
            123            scanf("%d %d"&s, &e);
            124
            125            printf("%d\n", Query( s, e ));
            126
            127        }

            128
            129    }

            130
            131    return 0;
            132}
            posted on 2009-05-08 08:00 閱讀(135) 評(píng)論(0)  編輯 收藏 引用 所屬分類(lèi): 數(shù)據(jù)結(jié)構(gòu)
            A狠狠久久蜜臀婷色中文网| 久久久久无码精品国产| 久久精品无码专区免费东京热| 品成人欧美大片久久国产欧美| 久久成人国产精品| 久久人妻少妇嫩草AV无码专区| 久久91精品国产91| 超级碰碰碰碰97久久久久| 免费精品国产日韩热久久| 午夜精品久久久久久影视777| 久久精品国产一区二区三区不卡| 99久久99久久精品国产| 99久久精品无码一区二区毛片| 久久精品一区二区国产| 伊人久久大香线焦综合四虎| 久久精品一区二区三区不卡| 成人精品一区二区久久| 久久国产成人午夜AV影院| 久久久久亚洲精品中文字幕| 热久久最新网站获取| 亚洲国产一成人久久精品| 久久久久久午夜成人影院 | 久久不见久久见免费视频7| 无码国产69精品久久久久网站| 精品综合久久久久久888蜜芽| 成人久久综合网| 精品无码人妻久久久久久| 欧美麻豆久久久久久中文| 欧美亚洲国产精品久久| 精品永久久福利一区二区| 国内精品久久久久久久coent| 日产久久强奸免费的看| 日日噜噜夜夜狠狠久久丁香五月| 99国产欧美精品久久久蜜芽| 精品久久久久久无码国产| 一级女性全黄久久生活片免费| 国产精品无码久久久久久| 久久精品国产99久久香蕉| 亚洲乱码精品久久久久..| 中文字幕成人精品久久不卡| 久久91精品国产91|