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

            ACM PKU 1125 Stockbroker Grapevine 圖論 Floyd算法

            http://acm.pku.edu.cn/JudgeOnline/problem?id=1125 

            Stockbroker Grapevine 

            Time Limit:1000MS  Memory Limit:10000K 
            Total Submit:2602 Accepted:1503 
            Description Stockbrokers are known to overreact to rumours. You have been contracted to develop a method of spreading disinformation amongst the stockbrokers to give your employer the tactical edge in the stock market. For maximum effect, you have to spread the rumours in the fastest possible way. 

            Unfortunately for you, stockbrokers only trust information coming from their "Trusted sources" This means you have to take into account the structure of their contacts when starting a rumour. It takes a certain amount of time for a specific stockbroker to pass the rumour on to each of his colleagues. Your task will be to write a program that tells you which stockbroker to choose as your starting point for the rumour, as well as the time it will take for the rumour to spread throughout the stockbroker community. This duration is measured as the time needed for the last person to receive the information. 
            Input 
            Your program will input data for different sets of stockbrokers. Each set starts with a line with the number of stockbrokers. Following this is a line for each stockbroker which contains the number of people who they have contact with, who these people are, and the time taken for them to pass the message to each person. The format of each stockbroker line is as follows: The line starts with the number of contacts (n), followed by n pairs of integers, one pair for each contact. Each pair lists first a number referring to the contact (e.g. a '1' means person number one in the set), followed by the time in minutes taken to pass a message to that person. There are no special punctuation symbols or spacing rules. 

            Each person is numbered 1 through to the number of stockbrokers. The time taken to pass the message on will be between 1 and 10 minutes (inclusive), and the number of contacts will range between 0 and one less than the number of stockbrokers. The number of stockbrokers will range from 1 to 100. The input is terminated by a set of stockbrokers containing 0 (zero) people. 


            Output 
            For each set of data, your program must output a single line containing the person who results in the fastest message transmission, and how long before the last person will receive any given message after you give it to this person, measured in integer minutes. 
            It is possible that your program will receive a network of connections that excludes some persons, i.e. some people may be unreachable. If your program detects such a broken network, simply output the message "disjoint". Note that the time taken to pass the message from person A to person B is not necessarily the same as the time taken to pass it from B to A, if such transmission is possible at all. 
            Sample Input 
            32 2 4 3 52 1 2 3 62 1 2 2 253 4 4 2 8 5 31 5 84 1 6 4 10 2 7 5 202 2 5 1 50 


            Sample Output 
            3 23 10 


            Source 
            Southern African 2001 

            —————————————————————————————————————————————————— 
            Floyd-Warshall算法是解決任意兩點間的最短路徑的一種算法,可以正確處理有向圖(Directed Graph)或負數的代價(negtive cost)的最短路徑問題。Floyd-Warshall算法的時間復雜度為<math>O(N^3)</math>。 
             Floyd-Warshall算法的描述如下: 
             
            for k  1 to n do
              for i  1 to n do  
                for j  1 to n do
                  if (<math>D_{i,k} + D_{k,j} < D_{i,j}</math>) then      
                      <math>D_{i,j}</math>  <math>D_{i,k} + D_{k,j}</math>; 
             
            其中<math>D_{i,j}</math>表示由點<math>i</math>到點<math>j</math>的代價(cost),當<math>D_{i,j}</math>為 ∞ 表示兩點之間沒有任何連接(Disconnected)。 

            Floyd算法也可以說是動態規劃。 


            Source
            Problem Id:1125  User Id:lnmm 

            Memory:84K  Time:0MS 
            Language:C++  Result:Accepted 

             1#include"stdio.h" 
             2int a[101][101]; 
             3int i,j,k=0
             4int min; 
             5int max[101]; 
             6int T; 
             7int n,m,temp,to; 
             8int flag; 
             9void main() 
            10
            11while(scanf("%d",&n)&&n!=0)    //讀入一個set的人數 
            12
            13       for(i=1;i<=n;i++
            14     for(j=1;j<=n;j++
            15        a[i][j]=32767
            16  for(i=1;i<=n;i++
            17   a[i][i]=0;              //初識化該set的矩陣 
            18  for(i=1;i<=n;i++)           //讀入一個set的數據 
            19  
            20   scanf("%d",&m); 
            21   for(j=1;j<=m;j++
            22   
            23    scanf("%d %d",&to,&temp); 
            24    a[i][to]=temp; 
            25   }
             
            26  }
             
            27  for(k=1;k<=n;k++)             //弗洛伊德算法 
            28   for(i=1;i<=n;i++
            29    for(j=1;j<=n;j++
            30    
            31     if(a[i][k]!=32767 && a[k][j]!=32767 && a[i][j]>a[i][k]+a[k][j]) 
            32      a[i][j]=a[i][k]+a[k][j]; 
            33    }
             
            34
            35         
            36  flag=0
            37  for(i=1;i<=n;i++)                        //求出從i人開始,謠言傳遞需要的時間 
            38  {   max[i]=0
            39   for(j=1;j<=n;j++
            40   
            41    if(max[i]<a[i][j])max[i]=a[i][j]; 
            42   }
             
            43       
            44  }
             
            45   
            46  min=32767;                                //計算最小謠言時間
            47  for(i=1;i<=n;i++
            48   if(min>max[i]) 
            49   {min=max[i]; 
            50   k=i; 
            51   }
             
            52  if(min==32767)printf("disjoint.\n");            
            53  else printf("%d %d\n",k,min); 
            54
            55   
            56}
             
            57     
            58}


             

            posted on 2007-09-14 02:00 流牛ζ木馬 閱讀(1831) 評論(2)  編輯 收藏 引用

            評論

            # re: ACM PKU 1125 Stockbroker Grapevine 圖論 Floyd算法 2009-05-10 13:12 朱一帆

            我說樓主啊,你能不能不要那么自大啊,你的程序的結果是WA啊!!!  回復  更多評論   

            # re: ACM PKU 1125 Stockbroker Grapevine 圖論 Floyd算法 2009-05-14 00:09 zx

            果然是WA,樓主,要改改啦!  回復  更多評論   

            <2007年9月>
            2627282930311
            2345678
            9101112131415
            16171819202122
            23242526272829
            30123456

            導航

            統計

            公告

            MY Email/MSN :mars1021@163.com QQ : 27402040 流牛ζ木馬

            常用鏈接

            留言簿(6)

            隨筆檔案

            相冊

            搜索

            最新隨筆

            最新評論

            閱讀排行榜

            評論排行榜

            亚洲精品成人久久久| 久久夜色精品国产亚洲| 三级片免费观看久久| 精品久久久中文字幕人妻 | 狠狠色噜噜色狠狠狠综合久久| 亚洲女久久久噜噜噜熟女| 女人香蕉久久**毛片精品| 一本一本久久A久久综合精品| 国产精品成人无码久久久久久 | 一级做a爰片久久毛片毛片| 久久99精品久久久久久久不卡| 久久久久无码专区亚洲av| 久久久久亚洲AV无码专区体验| 久久最新免费视频| 亚洲综合精品香蕉久久网97| 久久婷婷成人综合色综合| 久久国产亚洲精品| 久久夜色精品国产亚洲av| 中文精品久久久久国产网址| 伊人久久大香线蕉av一区| 亚洲欧美日韩精品久久亚洲区 | 国产精品久久久久久影院 | 青青青国产精品国产精品久久久久 | 久久久亚洲精品蜜桃臀 | 99久久综合国产精品免费 | 国产亚洲欧美精品久久久 | 精品欧美一区二区三区久久久 | 色欲综合久久躁天天躁| 一本大道久久a久久精品综合| 久久亚洲综合色一区二区三区| 久久精品人人做人人爽97| 久久精品黄AA片一区二区三区 | 久久人人爽人人爽人人片AV麻豆 | 性做久久久久久久久久久| 久久国产影院| 午夜肉伦伦影院久久精品免费看国产一区二区三区| 激情伊人五月天久久综合| 精品午夜久久福利大片| 亚洲国产精品久久久久网站| 国产三级精品久久| 亚洲国产成人久久综合碰|