• <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
            數(shù)據(jù)加載中……

            POJ 3039 Skiing 單源最短路徑

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

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

            #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 糯米 閱讀(474) 評論(0)  編輯 收藏 引用 所屬分類: POJ

            91精品国产综合久久婷婷| 伊人久久大香线蕉综合5g| 久久久久久久亚洲精品| 国产精品久久永久免费| 亚洲精品乱码久久久久66| 亚洲乱码中文字幕久久孕妇黑人| 精品久久人人妻人人做精品| 91麻精品国产91久久久久| 国产精品久久久久影院色| 国产精品久久久久9999| 国产成人精品白浆久久69| 99久久免费国产精品热| 狠狠狠色丁香婷婷综合久久俺| avtt天堂网久久精品| 久久久国产精品福利免费| 激情综合色综合久久综合| 精品无码久久久久久久久久| 无码人妻少妇久久中文字幕| 综合久久给合久久狠狠狠97色 | 久久婷婷五月综合色高清| 人妻久久久一区二区三区| 精品国产一区二区三区久久久狼| 国产精品18久久久久久vr| 国产精品久久亚洲不卡动漫| 精品熟女少妇aⅴ免费久久| 人妻中文久久久久| 蜜臀av性久久久久蜜臀aⅴ麻豆| 精品久久无码中文字幕| 久久婷婷五月综合97色直播| 久久久久久久精品成人热色戒 | 18岁日韩内射颜射午夜久久成人 | 精品水蜜桃久久久久久久| 99精品国产免费久久久久久下载| 久久精品午夜一区二区福利| 精品一久久香蕉国产线看播放| 亚洲欧美日韩精品久久亚洲区| 久久精品中文闷骚内射| 亚洲精品WWW久久久久久 | 996久久国产精品线观看| 久久久久国产一级毛片高清板| 久久国产劲爆AV内射—百度|