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

            superman

            聚精會神搞建設(shè) 一心一意謀發(fā)展
            posts - 190, comments - 17, trackbacks - 0, articles - 0
               :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

            POJ 3264 - Balanced Lineup

            Posted on 2008-05-25 16:07 superman 閱讀(339) 評論(0)  編輯 收藏 引用 所屬分類: POJ
             1 /* Accepted 6888K 3141MS G++ 1416B */
             2 #include <math.h>
             3 #include <iostream>
             4 
             5 using namespace std;
             6 
             7 int n, m;
             8 int A[50000];
             9 int MIN[50000][16];
            10 int MAX[50000][16];
            11 
            12 void init()
            13 {
            14     for(int i = 0; i < n; i++)
            15         MIN[i][0= MAX[i][0= A[i];
            16     for(int j = 11 << j <= n; j++)
            17         for(int i = 0; i + (1 << j) - 1 < n; i++)
            18         {
            19             if(MIN[i][j - 1< MIN[i + (1 << (j - 1))][j - 1])
            20                 MIN[i][j] = MIN[i][j - 1];
            21             else
            22                 MIN[i][j] = MIN[i + (1 << (j - 1))][j - 1];
            23             
            24             if(MAX[i][j - 1> MAX[i + (1 << (j - 1))][j - 1])
            25                 MAX[i][j] = MAX[i][j - 1];
            26             else
            27                 MAX[i][j] = MAX[i + (1 << (j - 1))][j - 1];
            28         }
            29 }
            30 
            31 int main()
            32 {
            33     scanf("%d %d"&n, &m);
            34     for(int i = 0; i < n; i++)
            35         scanf("%d"&A[i]);
            36     
            37     //ST algorithm
            38     init();
            39     
            40     //deal with query
            41     int s, t;
            42     while(m--)
            43     {
            44         scanf("%d %d"&s, &t);
            45         s--, t--;
            46         
            47         int a, b, k = int(log(t - s + 1/ log(2));
            48         
            49         if(MIN[s][k] < MIN[t - (1 << k) + 1][k])
            50             a = MIN[s][k];
            51         else
            52             a = MIN[t - (1 << k) + 1][k];
            53         
            54         if(MAX[s][k] > MAX[t - (1 << k) + 1][k])
            55             b = MAX[s][k];
            56         else
            57             b = MAX[t - (1 << k) + 1][k];
            58         
            59         cout << b - a << endl;
            60     }
            61     
            62     return 0;
            63 }
            64 
            91精品国产91久久久久久青草| 亚洲国产成人久久综合一区77| 亚洲国产成人乱码精品女人久久久不卡| 久久精品国产亚洲av日韩 | 久久久久久毛片免费看| 中文成人久久久久影院免费观看| 91久久精品国产免费直播| 久久国产乱子精品免费女| 狠狠狠色丁香婷婷综合久久俺| 99久久人妻无码精品系列| 久久发布国产伦子伦精品 | 久久这里只有精品久久| 丁香狠狠色婷婷久久综合| 欧美一区二区三区久久综| 人妻少妇久久中文字幕| 国产精品99久久99久久久| 久久亚洲精品中文字幕三区| 色综合久久最新中文字幕| 久久久久久国产a免费观看不卡| 欧美久久久久久午夜精品| 亚洲国产成人精品91久久久 | 久久久久久亚洲精品不卡| 亚洲国产日韩欧美综合久久| 99久久精品免费看国产一区二区三区 | 国内精品伊人久久久久av一坑| 国产精品久久久久久久| 精品久久久久久无码免费| 久久久久久国产精品无码下载| 久久国产精品一国产精品金尊| 久久99亚洲综合精品首页| 久久99热这里只有精品国产| 国产精品视频久久久| 久久久久久久久久免免费精品 | 国产成人精品免费久久久久| 日本精品久久久久中文字幕8| 欧美日韩成人精品久久久免费看| 亚洲AV无码久久| 香蕉aa三级久久毛片| 99久久国产综合精品成人影院 | 久久亚洲精精品中文字幕| 久久久精品日本一区二区三区|