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

            糯米

            TI DaVinci, gstreamer, ffmpeg
            隨筆 - 167, 文章 - 0, 評論 - 47, 引用 - 0
            數據加載中……

            POJ 3039 Skiing 單源最短路徑

            這題看起來很屌。
            但是實際上走到每個點之后,速度必然是當前點和左上角點的差值的倒數。
            所以,每個點到其他點的所花費的時間都是這個點自己的值決定的。
            而且沒可能經過一個點兩次的,因為經過兩次肯定是浪費時間的。
            問題就變成了求最短路徑。

            注意:
            這題的精度很莫名其妙,用C++可以AC的,G++、GCC都是WA。
            不能用整數來保存時間,雖然看上去位數是夠用的,但是遇到比較屌的數據就掛了。
            就在這個問題上杯具了很久。

            #include <stdio.h>
            #include 
            <math.h>

            #ifndef _countof
            #define _countof(x) (sizeof(x)/sizeof(x[0]))
            #endif

            #define SIZE 128

            int map[SIZE][SIZE], R, C, V;
            double D[SIZE][SIZE], _tbl[128], *tbl = &_tbl[64];
            int queue[65536][2], head, tail;
            int vis[SIZE][SIZE];

            inline 
            void push(int y, int x, double d)
            {
                
            if (y < 0 || y >= R || x < 0 || x >= C)
                    
            return ;
                
            if (d > D[y][x])
                    
            return ;
                D[y][x] 
            = d;
                
            if (vis[y][x])
                    
            return ;
                vis[y][x] 
            = 1;
                queue[tail][
            0= y;
                queue[tail][
            1= x;
                tail
            ++;
                tail 
            &= _countof(queue) - 1;
            }


            inline 
            void pop(int *y, int *x)
            {
                
            *= queue[head][0];
                
            *= queue[head][1];
                head
            ++;
                head 
            &= _countof(queue) - 1;
                vis[
            *y][*x] = 0;
            }


            int main()
            {
                
            int i, j;
                
            double d;

                freopen(
            "e:\\test\\in.txt""r", stdin);

                
            for (i = -64; i <= 64; i++)
                    tbl[i] 
            = pow(2.0, i);

                scanf(
            "%d%d%d"&V, &R, &C);
                
            for (i = 0; i < R; i++{
                    
            for (j = 0; j < C; j++{
                        scanf(
            "%d"&map[i][j]);
                        
            if (i || j)
                            map[i][j] 
            -= map[0][0];
                        D[i][j] 
            = 1e80;
                    }

                }

                map[
            0][0= 0;

                push(
            000); 
                
            while (head != tail) {
                    pop(
            &i, &j);
                    d 
            = D[i][j] + tbl[map[i][j]];
                    push(i 
            + 1, j, d);
                    push(i 
            - 1, j, d);
                    push(i, j 
            + 1, d);
                    push(i, j 
            - 1, d);
                }


                printf(
            "%.2lf\n", D[R - 1][C - 1/ V);
                
                
            return 0;
            }

            posted on 2010-04-12 16:45 糯米 閱讀(475) 評論(0)  編輯 收藏 引用 所屬分類: POJ

            精品久久久久久无码专区不卡| 久久久久亚洲精品天堂久久久久久| 久久精品中文字幕一区| 人妻系列无码专区久久五月天| 中文字幕无码久久人妻| 久久99精品国产麻豆宅宅| 国产精品青草久久久久福利99| 亚洲人成网站999久久久综合| 韩国免费A级毛片久久| 精品久久国产一区二区三区香蕉| 欧美成人免费观看久久| 久久久国产精品福利免费| 久久这里只精品99re66| 99精品久久久久久久婷婷| 亚洲中文久久精品无码ww16| 久久久久国产亚洲AV麻豆| 国产精品99久久免费观看| 99久久国产综合精品女同图片| 久久er国产精品免费观看8| avtt天堂网久久精品| 久久精品国产免费观看| 久久一区二区免费播放| 国产成人综合久久精品尤物| 97久久天天综合色天天综合色hd| 国产精品久久新婚兰兰| 久久这里都是精品| 思思久久精品在热线热| 蜜臀久久99精品久久久久久| 国产巨作麻豆欧美亚洲综合久久 | 久久人人爽人人爽人人AV| 久久久久国产亚洲AV麻豆| 亚洲国产精品久久久久久| 99久久精品午夜一区二区| 精品国产一区二区三区久久久狼 | 狠色狠色狠狠色综合久久| 亚洲香蕉网久久综合影视| 久久精品国产亚洲av麻豆蜜芽 | 97r久久精品国产99国产精| 久久91精品国产91久久户| 色综合久久88色综合天天| 7国产欧美日韩综合天堂中文久久久久|