• <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>
            posts - 16,comments - 0,trackbacks - 0

            二維RMQ

            # include <stdio.h>

            # define N 
            255
            # define L 
            8

            int n, b, k, ll, jj;
            int h[N][N];
            int mx[N][N][L], mn[N][N][L];

            int Max(int x, int y)
            {
                
            return x > y ? x : y;
            }


            int Min(int x, int y)
            {
                
            return x < y ? x : y;
            }


            void init(void)
            {
                
            int i, j;
                scanf(
            "%d%d%d"&n, &b, &k);
                
            for (i = 1; i <= n; ++i)
                
            for (j = 1; j <= n; ++j)
                
            {
                    scanf(
            "%d"&h[i][j]);
                    mx[i][j][
            0= mn[i][j][0= h[i][j];
                }

            }


            void prep(void)
            {
                
            int p, q, j, l;
                jj 
            = 0, ll = 1;
                
            while (ll*2 <= b) ++jj, ll *= 2;
                
            for (j = 1, l = 1; l <= ll; l *= 2++j)
                
            for (p = 1; p+l*2 <= n+1++p)
                
            for (q = 1; q+l*2 <= n+1++q)
                
            {
                    mx[p][q][j] 
            = Max(Max(mx[p][q][j-1], mx[p+l][q+l][j-1]),
                                      Max(mx[p][q
            +l][j-1], mx[p+l][q][j-1]));
                    mn[p][q][j] 
            = Min(Min(mn[p][q][j-1], mn[p+l][q+l][j-1]),
                                      Min(mn[p][q
            +l][j-1], mn[p+l][q][j-1]));
                    
            //printf("%d %d\t%d %d\t%d\n", p, q, mx[p][q][j], mn[p][q][j], l);
                }

            }


            int rmq(int x, int y)
            {
                
            /*
                int s, t;
                s = Max(Max(mx[x][y][jj], mx[x+b-ll][y+b-ll][jj]),
                           Max(mx[x+b-ll][y][jj], mx[x][y+b-ll][jj]));
                t = Min(Min(mn[x][y][jj], mn[x+b-ll][y+b-ll][jj]),
                           Min(mn[x+b-ll][y][jj], mn[x][y+b-ll][jj]));
                printf("%d\t%d\n", s, t);
                
            */

                
            return Max(Max(mx[x][y][jj], mx[x+b-ll][y+b-ll][jj]),
                           Max(mx[x
            +b-ll][y][jj], mx[x][y+b-ll][jj])) -
                       Min(Min(mn[x][y][jj], mn[x
            +b-ll][y+b-ll][jj]),
                           Min(mn[x
            +b-ll][y][jj], mn[x][y+b-ll][jj]));
            }


            void solve(void)
            {
                
            int i, x, y;
                
            for (i = 1; i <= k; ++i)
                
            {
                    scanf(
            "%d%d"&x, &y);
                    printf(
            "%d\n", rmq(x, y));
                }

            }


            int main()
            {
            //    freopen("test.in", "r", stdin);

                init();
                prep();
                solve();

                
            return 0;
            }

             

            posted on 2012-08-27 09:00 yajunw 閱讀(121) 評論(0)  編輯 收藏 引用

            只有注冊用戶登錄后才能發(fā)表評論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            97超级碰碰碰久久久久| 中文字幕人妻色偷偷久久| 精品久久久无码人妻中文字幕| 99久久国产亚洲高清观看2024| 久久久久久九九99精品| 伊人久久大香线蕉亚洲| 久久婷婷五月综合成人D啪| 亚洲精品tv久久久久| 欧美日韩精品久久久免费观看| 亚洲一区精品伊人久久伊人| 免费久久人人爽人人爽av| 伊人久久大香线蕉av一区| 波多野结衣中文字幕久久| 1000部精品久久久久久久久| 青青青青久久精品国产| 久久久无码精品亚洲日韩软件| 日韩十八禁一区二区久久| 91麻豆国产精品91久久久| 久久精品中文闷骚内射| 伊人久久大香线蕉影院95| 久久久艹| 无码人妻久久一区二区三区免费丨| 久久66热人妻偷产精品9| 丰满少妇人妻久久久久久4| 午夜精品久久久久久影视777| 久久久久av无码免费网| 欧美激情精品久久久久| 亚洲精品综合久久| 国内精品久久久久影院一蜜桃 | 欧美一级久久久久久久大片| 亚洲精品国产第一综合99久久| 久久久久久夜精品精品免费啦| 国产高潮国产高潮久久久91| 奇米影视7777久久精品人人爽| avtt天堂网久久精品| 亚洲国产成人精品无码久久久久久综合| 久久精品国产亚洲αv忘忧草 | 久久66热人妻偷产精品9| 久久WWW免费人成—看片| 色欲综合久久躁天天躁蜜桃| 久久99热这里只有精品国产|