• <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 田兵 閱讀(1437) 評論(1)  編輯 收藏 引用 所屬分類: 圖論題

            <2010年8月>
            25262728293031
            1234567
            891011121314
            15161718192021
            22232425262728
            2930311234

            導航

            統計

            常用鏈接

            留言簿(2)

            隨筆分類(65)

            隨筆檔案(65)

            文章檔案(2)

            ACM

            搜索

            積分與排名

            最新隨筆

            最新評論

            閱讀排行榜

            国产精品欧美久久久久天天影视| 亚洲第一极品精品无码久久| 欧美久久久久久精选9999| 国产视频久久| 亚洲精品乱码久久久久久久久久久久| 奇米影视7777久久精品| 久久99精品国产麻豆不卡| 一本一本久久aa综合精品| 精品国产热久久久福利| 久久婷婷国产综合精品| 久久久综合香蕉尹人综合网| 久久人人爽人人爽人人AV | 一本色道久久88综合日韩精品| 伊人久久综合精品无码AV专区| 久久www免费人成看国产片| 久久精品亚洲日本波多野结衣| 欧美伊人久久大香线蕉综合69| 91精品国产综合久久精品| 精品多毛少妇人妻AV免费久久| 久久播电影网| 7国产欧美日韩综合天堂中文久久久久| av色综合久久天堂av色综合在| 国产精品免费久久久久电影网| 99精品国产在热久久无毒不卡| 久久久久久久久久久| 午夜精品久久久久9999高清| 91精品国产综合久久四虎久久无码一级| 天天躁日日躁狠狠久久| 人妻丰满AV无码久久不卡| 97久久国产露脸精品国产| 一本久久a久久精品vr综合| 久久久亚洲裙底偷窥综合| 中文字幕亚洲综合久久菠萝蜜| 久久夜色撩人精品国产| 亚洲va久久久久| 人妻丰满AV无码久久不卡| 欧洲人妻丰满av无码久久不卡| 久久九九精品99国产精品| 久久国产色AV免费观看| 久久狠狠色狠狠色综合| 成人精品一区二区久久|