• <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++)//估計計距離最小的頂點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 閱讀(1844) 評論(6)  編輯 收藏 引用 所屬分類: pku

            評論:
            # re: pku 2253 Frogger 2008-11-06 22:51 | Wang Feng
            acm中如果涉及到圖的算法,可否直接使用boost graph library?  回復  更多評論
              
            # re: pku 2253 Frogger[未登錄] 2008-11-07 23:34 | cdy20
            一般自己寫,不用庫的。
            庫的靈活性不會好
            而且主要還是運行時間的問題
            有些題目,用類庫的很容易超時。@Wang Feng
              回復  更多評論
              
            # re: pku 2253 Frogger 2009-03-29 10:56 | 12342
            你好,請問
            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]);
            }
            這是什么意思啊,這幾步的詳細作用是什么?謝謝,麻煩解釋一下!
              回復  更多評論
              
            # re: pku 2253 Frogger[未登錄] 2009-03-29 22:15 | cdy20
            @12342
            這是最基本的更新的
            d[i]表示源點到點i的路徑距離,這里取它最小的數
            min( max(dist[k],mat[k][i]),dist[i]);
            其中max(dist[k],mat[k][i])這一句表示每次跳,選擇的步子最長的
            min表示最短路的,有點dp的思想 min(d[i])
            每次更新d[i]
            。。。。。
            好好看題目的。“
            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.


              回復  更多評論
              
            # re: pku 2253 Frogger[未登錄] 2009-03-29 22:18 | cdy20
            這只froger每次跳的時候找鄰近可以跳的石頭,找那個些盡可能距離遠的

            然后總體結果路徑要想最短的
              回復  更多評論
              
            # re: pku 2253 Frogger 2009-03-30 13:51 | 12342
            又去看了看dijkstra,終于明白了!謝謝啊!!!  回復  更多評論
              
            欧洲性大片xxxxx久久久| 精品永久久福利一区二区| 99久久国产热无码精品免费久久久久| 国产69精品久久久久777| 一级做a爱片久久毛片| 亚洲国产精品综合久久一线| 少妇熟女久久综合网色欲| 久久99国产乱子伦精品免费| 久久久精品国产亚洲成人满18免费网站| 久久亚洲国产成人影院网站| 欧美大香线蕉线伊人久久| 久久996热精品xxxx| 97精品依人久久久大香线蕉97| 久久精品国产精品青草app| 日韩电影久久久被窝网| 国产精品美女久久久久久2018| 人妻无码久久精品| 久久这里只有精品久久| 人人狠狠综合久久88成人| 久久婷婷人人澡人人| 久久青草国产手机看片福利盒子| 久久午夜无码鲁丝片秋霞| 大香网伊人久久综合网2020| 亚洲精品美女久久777777| 精品久久久久久无码国产| 蜜臀av性久久久久蜜臀aⅴ | 一本色道久久88精品综合| 国产精品成人99久久久久| 天天爽天天爽天天片a久久网| 久久精品国产AV一区二区三区| 色悠久久久久久久综合网| 精品免费久久久久国产一区| 亚洲精品高清久久| 成人a毛片久久免费播放| 中文精品久久久久国产网址| AAA级久久久精品无码片| 久久久久久久人妻无码中文字幕爆 | 色欲综合久久中文字幕网| 国产aⅴ激情无码久久| 亚洲成色WWW久久网站| 久久亚洲精精品中文字幕|