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

            USACO--AOJ Bessie Come Home --Floyd算法

            Bessie Come Home

            Time Limit:JAVA/Others2000/1000MS  Memory Limit:JAVA/Others131072/65536KB
            Total Submit:6 Accepted:2

            Description

            It's dinner time, and the cows are out in their separate pastures. Farmer John rings the bell so they will start walking to the barn. Your job is to figure out which one cow gets to the barn first (the supplied test data will always have exactly one fastest cow).

            Between milkings, each cow is located in her own pasture, though some pastures have no cows in them. Each pasture is connected by a path to one or more other pastures (potentially including itself). Sometimes, two (potentially self-same) pastures are connected by more than one path. One or more of the pastures has a path to the barn. Thus, all cows have a path to the barn and they always know the shortest path. Of course, cows can go either direction on a path and they all walk at the same speed.

            The pastures are labeled `a'..`z' and `A'..`Y'. One cow is in each pasture labeled with a capital letter. No cow is in a pasture labeled with a lower case letter. The barn's label is `Z'; no cows are in the barn, though.

            Input

            Line 1: Integer P (1 <= P <= 10000) the number of paths that interconnect the pastures (and the barn)
            Line 2..P+1: Space separated, two letters and an integer: the names of the interconnected pastures/barn and the distance between them (1 <= distance <= 1000)

            Output

            A single line containing two items: the capital letter name of the pasture of the cow that arrives first back at the barn, the length of the path followed by that cow.

            Sample Input

            5
            A d 6
            B d 3
            C e 9
            d Z 8
            e Z 3
            

            Sample Output

            B 11
            

             1Floyd 算法:http://icpc.ahu.edu.cn:8080/AOJ/   做的第一個圖論題
             2圖的最短路徑問題,到‘Z’的最短路徑;
             3Floyd算法大概知道怎么用了 ,好像是動態規劃實現的,不知道為什么這樣是對的
             4O(N^3)求解最短路徑問題,數據范圍超過400可能就危險了
             5#include<iostream>
             6#include<string.h>
             7using namespace std;
             8int dis[53][53];
             9const int INF=10000000;
            10void Floyd(int n)
            11{
            12     for(int k=1; k<=n; k++)
            13     for(int i=1; i<=n; i++)
            14     for(int j=1; j<=n; j++)
            15      if(i!=k&&k!=j&&i!=j&&dis[i][k]+dis[k][j]<dis[i][j])
            16      dis[i][j]=dis[i][k]+dis[k][j];
            17
            18}

            19
            20
            21int main()
            22{
            23    int p,i,j,k,d,n1,n2; 
            24    cin>>p;
            25    memset(dis,0,sizeof (dis));
            26    for(i=1; i<=52; i++)
            27    for(j=1; j<=52; j++)
            28    dis[i][j]=INF;
            29     
            30    for(i=1; i<=p; i++)
            31    {
            32       char v1,v2;
            33       cin>>v1>>v2>>d;      
            34       if(v1==v2)continue;
            35       n1=(v1>='a'?v1-'a'+1:v1-'A'+26+1);
            36       n2=(v2>='a'?v2-'a'+1:v2-'A'+26+1);
            37       if(d<dis[n1][n2])dis[n1][n2]=dis[n2][n1]=d;
            38    }

            39    
            40    Floyd(52);
            41    
            42    int min=INF+100;
            43    char c;
            44    for(i=27; i<=51; i++//大寫字母到Z 
            45    {
            46       if(dis[i][52]<min){min=dis[i][52];c=i; }
            47    }

            48    cout<<char(c-27+'A')<<' '<<min<<endl;
            49    //system("pause");
            50    return 0;
            51}

            52

            posted on 2010-05-23 20:03 田兵 閱讀(1428) 評論(1)  編輯 收藏 引用 所屬分類: 圖論題

            <2010年5月>
            2526272829301
            2345678
            9101112131415
            16171819202122
            23242526272829
            303112345

            導航

            統計

            常用鏈接

            留言簿(2)

            隨筆分類(65)

            隨筆檔案(65)

            文章檔案(2)

            ACM

            搜索

            積分與排名

            最新隨筆

            最新評論

            閱讀排行榜

            国产精品一区二区久久精品无码 | 久久高潮一级毛片免费| 日韩亚洲欧美久久久www综合网| 国产精品久久久久一区二区三区| 夜夜亚洲天天久久| 久久久久久久97| 日韩久久无码免费毛片软件| 久久精品国产亚洲AV大全| 久久综合综合久久97色| 亚洲欧洲精品成人久久奇米网| 97久久久精品综合88久久| 久久精品国产亚洲av麻豆蜜芽| 日韩亚洲欧美久久久www综合网| 免费一级做a爰片久久毛片潮| 99久久夜色精品国产网站| 中文字幕人妻色偷偷久久| 狠狠色婷婷久久综合频道日韩| 狠狠色丁香久久婷婷综| 99热成人精品热久久669| 免费一级欧美大片久久网| 99久久精品国产一区二区| 少妇高潮惨叫久久久久久| 国内精品九九久久久精品| 色综合久久久久网| 99久久国产热无码精品免费| 精品国产乱码久久久久软件| 精品国产青草久久久久福利| 久久国产精品视频| 日本精品久久久久中文字幕| 波多野结衣久久| 国内精品久久久久影院老司| 无码精品久久一区二区三区| 久久久91人妻无码精品蜜桃HD | 久久ZYZ资源站无码中文动漫| 亚洲国产日韩欧美久久| 久久男人AV资源网站| 久久无码国产| 亚洲精品国产综合久久一线| 久久久久无码国产精品不卡| 伊色综合久久之综合久久| 久久无码AV一区二区三区|