• <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>
            我要啦免费统计
            http://acm.pku.edu.cn/JudgeOnline/problem?id=2253


            #include
            <iostream>
            #include
            <cmath>
            using namespace std;

            #define MAXN 1002
            #define inf 1000000000
            typedef 
            double elem_t;
            elem_t mat[MAXN][MAXN];
            elem_t dist[MAXN];
            int num[MAXN][2];

            double distance(int a1,int a2,int b1,int b2)
            {
                   
            return sqrt((double)((a1-b1)*(a1-b1)+(a2-b2)*(a2-b2)));
            }

            void dijkstra(int n,int s)
            {
                
            int v[MAXN],i,j;
                
            int k;
                
            for (i=0;i<n;i++)
                    dist[i]
            =mat[s][i],v[i]=0;//初始化
                
                
            for (dist[s]=0,j=0;j<n;j++){

                    
            for (k=-1,i=0;i<n;i++)//估計(jì)計(jì)距離最小的頂點(diǎn)k
                        if (!v[i]&&(k==-1||dist[i] < dist[k]))
                            k
            =i;

                    
            for (v[k]=1,i=0;i<n;i++)
                        
            if (!v[i] && mat[k][i]>0.0)//&& max(dist[k],mat[k][i]) > dist[i])
                            {
                                 dist[i] 
            = min( max(dist[k],mat[k][i]),dist[i]);
                                 
                              
            //dist[i]=min(dist[k],mat[k][i]);
                           }


                }

            }


            int main()
            {
                
                
            int n,m,k,x1,y1;
                
                
                
                
            for(int i = 1;;i ++){
                  scanf(
            "%d",&n);
                  
            if( n == 0)break;
                   memset(mat,
            0,sizeof(mat));
                   
            forint j=0;j<n;j++)
                     scanf(
            "%d %d",&num[j][0],&num[j][1]);
                   
            forint k=0;k<n;k++)
                     
            forint j=0;j<n;j++){
                        mat[k][j]
            =distance(num[k][0],num[k][1],num[j][0],num[j][1]);     
                     }


                   

                   dijkstra(n,
            0);

                   printf(
            "Scenario #%d\n",i);
                   printf(
            "Frog Distance = %0.3lf\n\n",dist[1]);//dist[n-1]<<endl<<endl;
                }


                
            return 0;
            }


            /*
            1
            3 3
            1 2 3
            1 3 4
            2 3 5

            */

            posted on 2008-11-06 21:55 閱讀(1852) 評(píng)論(6)  編輯 收藏 引用 所屬分類: pku

            評(píng)論:
            # re: pku 2253 Frogger 2008-11-06 22:51 | Wang Feng
            acm中如果涉及到圖的算法,可否直接使用boost graph library?  回復(fù)  更多評(píng)論
              
            # re: pku 2253 Frogger[未登錄] 2008-11-07 23:34 | cdy20
            一般自己寫,不用庫的。
            庫的靈活性不會(huì)好
            而且主要還是運(yùn)行時(shí)間的問題
            有些題目,用類庫的很容易超時(shí)。@Wang Feng
              回復(fù)  更多評(píng)論
              
            # re: pku 2253 Frogger 2009-03-29 10:56 | 12342
            你好,請(qǐng)問
            for (v[k]=1,i=0;i<n;i++)
            if (!v[i] && mat[k][i]>0.0)//&& max(dist[k],mat[k][i]) > dist[i])
            {
            dist[i] = min( max(dist[k],mat[k][i]),dist[i]);

            //dist[i]=min(dist[k],mat[k][i]);
            }
            這是什么意思啊,這幾步的詳細(xì)作用是什么?謝謝,麻煩解釋一下!
              回復(fù)  更多評(píng)論
              
            # re: pku 2253 Frogger[未登錄] 2009-03-29 22:15 | cdy20
            @12342
            這是最基本的更新的
            d[i]表示源點(diǎn)到點(diǎn)i的路徑距離,這里取它最小的數(shù)
            min( max(dist[k],mat[k][i]),dist[i]);
            其中max(dist[k],mat[k][i])這一句表示每次跳,選擇的步子最長的
            min表示最短路的,有點(diǎn)dp的思想 min(d[i])
            每次更新d[i]
            。。。。。
            好好看題目的?!?br>To execute a given sequence of jumps, a frog's jump range obviously must be at least as long as the longest jump occuring in the sequence.
            The frog distance (humans also call it minimax distance) between two stones therefore is defined as the minimum necessary jump range over all possible paths between the two stones.


              回復(fù)  更多評(píng)論
              
            # re: pku 2253 Frogger[未登錄] 2009-03-29 22:18 | cdy20
            這只froger每次跳的時(shí)候找鄰近可以跳的石頭,找那個(gè)些盡可能距離遠(yuǎn)的

            然后總體結(jié)果路徑要想最短的
              回復(fù)  更多評(píng)論
              
            # re: pku 2253 Frogger 2009-03-30 13:51 | 12342
            又去看了看dijkstra,終于明白了!謝謝?。。?!  回復(fù)  更多評(píng)論
              
            无码国产69精品久久久久网站| 久久综合香蕉国产蜜臀AV| 精品久久久久中文字幕日本| 狠狠色丁香婷婷久久综合不卡| 香蕉久久夜色精品国产小说| 精品无码久久久久久久动漫| 久久夜色精品国产亚洲| 久久精品国产99国产精偷| 精品久久久久久无码中文野结衣| 中文字幕精品无码久久久久久3D日动漫 | 99久久国产宗和精品1上映| 久久久久久亚洲Av无码精品专口| 国产福利电影一区二区三区久久久久成人精品综合 | 亚洲午夜久久久影院| 国产成人综合久久综合| 午夜精品久久久久久| 国产精品99久久99久久久| 久久亚洲精品国产亚洲老地址| 久久精品国产亚洲AV麻豆网站| 久久久久亚洲精品中文字幕| 97久久香蕉国产线看观看| 久久亚洲中文字幕精品一区| 久久久久国色AV免费观看| 99久久99久久| 久久久久亚洲精品天堂| 狠狠色婷婷久久综合频道日韩 | 伊人久久大香线蕉AV一区二区| 中文精品久久久久国产网址| 久久精品国产亚洲av日韩| 免费无码国产欧美久久18| 久久99精品久久久久久不卡| 久久青青草原国产精品免费 | 久久久久久久尹人综合网亚洲 | 香蕉久久夜色精品国产小说| 91精品国产乱码久久久久久 | 99国内精品久久久久久久| 国产精品久久午夜夜伦鲁鲁| 精品久久8x国产免费观看| 亚洲日本va中文字幕久久| 一本一本久久aa综合精品 | 久久人人超碰精品CAOPOREN |