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

            亚洲香蕉网久久综合影视| 亚洲Av无码国产情品久久| 久久精品日日躁夜夜躁欧美| 日批日出水久久亚洲精品tv| 久久精品国产一区二区三区| 久久精品国产亚洲AV影院| 久久久久免费看成人影片| 久久伊人色| 成人亚洲欧美久久久久| 欧美亚洲色综久久精品国产| 亚洲嫩草影院久久精品| 国产成人综合久久综合| 久久人人爽人人爽人人爽| 久久久久国产精品嫩草影院| 久久夜色精品国产噜噜麻豆 | 国产2021久久精品| 欧美亚洲国产精品久久高清| 亚洲精品视频久久久| 久久综合久久鬼色| 久久精品亚洲精品国产欧美| 国产叼嘿久久精品久久| 精品午夜久久福利大片| 久久97精品久久久久久久不卡| 国产精品久久久久蜜芽| 国产精品免费福利久久| 7国产欧美日韩综合天堂中文久久久久 | 久久精品国产一区二区三区日韩| 久久久久久精品成人免费图片 | 人妻少妇久久中文字幕| 97精品久久天干天天天按摩| 国产成人久久激情91| 久久激情亚洲精品无码?V| 亚洲国产小视频精品久久久三级 | 一个色综合久久| 精品久久久久久无码中文字幕一区 | 久久亚洲国产精品五月天婷| 性欧美丰满熟妇XXXX性久久久| 精品久久久久久久| 久久精品国产亚洲av麻豆图片 | 99精品国产综合久久久久五月天| 久久国产色AV免费观看|