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

            coreBugZJ

            此 blog 已棄。

            EOJ 1028 路由器

              1/*
              2EOJ 1028 路由器
              3
              4
              5----問題描述:
              6
              7路由器是網絡中用來轉發IP報文的一種設備。
              8
              9當路由器收到一個終端或者其它路由器發過來的報文時,它必須選項擇最快的一條通信線路通向報文所指向的目標機器(目標機器可能是一個終端,也可能是另一個路由器)。眾所周知,在兩個路由器之間可能有多條通信線路,你的任務就是給出兩個路由器之間最短通信時間。
             10每一個路由器都有一個IP來標識它自己,這個標識是唯一的。任意兩點之間的通信時間單位是毫秒。每條通信線路都是全雙工的(雙向的)。 
             11
             12
             13----輸入:
             14
             15第一行為兩個整數n和m,n表示有多少個路由器,m表示有多少條通信線路。(2<=n<=100,1<=m<=1000)
             16接下去的m行用來描述路由器之間的線路。每行包括三個元素,兩個路由器的IP地址和它們之間通信所花費的時間。
             17然后一行是一個整數t,表示有多少個報文。(1<=t<=1000)
             18接下去的t行是報文。每個報文占一行,為了簡化問題,我們在每行中給出兩個IP地址,分別是目標地址和源地址。你要做的就是求出兩者之間的最短時間。 
             19
             20
             21----輸出:
             22
             23對于每個報文,輸出一行。每行只包含一個整數,表示報文給的兩個IP地址之間的最短通信時間。如果不存在這樣的通路,或者IP地址并不存在,則輸出-1。 
             24
             25
             26----樣例輸入:
             27
             284 5
             29168.120.1.1 168.120.1.2 15
             30168.120.1.1 168.120.1.4 47
             31168.120.1.1 168.120.1.3 10
             32168.120.1.2 168.120.1.4 15
             33168.120.1.3 168.120.1.4 25
             343
             35168.120.1.1 168.120.1.4
             36168.120.1.3 168.120.1.4
             37168.120.1.3 202.12.12.12
             38
             39
             40----樣例輸出:
             41
             4230
             4325
             44-1 
             45
             46
             47----分析:
             48
             49
             50*/

             51
             52
             53#include <stdio.h>
             54#include <string.h>
             55
             56#define  N  102
             57#define  OO 1023456789
             58// OO + OO !!!!
             59
             60#define  IPL  20
             61int maxId;
             62char ipStr[N][IPL];
             63
             64int IpToId( const char * ip ){
             65        int i;
             66        for( i=1; i<=maxId; ++i ){
             67                if( strcmp( ip, ipStr[i] ) == 0 ){
             68                        return i;
             69                }

             70        }

             71        return 0;
             72}

             73
             74int main(){
             75        int w[N][N], i, j, k, n, m;
             76        char ip[IPL];
             77        scanf( "%d%d"&n, &m );
             78        maxId = 0;
             79        for( i=1; i<=n; ++i ){
             80                for( j=1; j<=n; ++j ){
             81                        w[i][j] = OO;
             82                }

             83        }

             84
             85        while( m-- ){
             86                scanf( "%s", ip );
             87                if( ( i = IpToId( ip ) ) == 0 ){
             88                        i = ++maxId;
             89                        strcpy( ipStr[maxId], ip );
             90                }

             91                scanf( "%s", ip );
             92                if( ( j = IpToId( ip ) ) == 0 ){
             93                        j = ++maxId;
             94                        strcpy( ipStr[maxId], ip );
             95                }

             96                scanf( "%d"&k );
             97                if( k < w[i][j] )/////////////////////////////
             98                        w[i][j] = w[j][i] = k;
             99                }

            100        }

            101
            102        for( k=1; k<=n; ++k ){
            103                for( i=1; i<=n; ++i ){
            104                        for( j=1; j<=n; ++j ){
            105                                if( (k!=j) && (k!=i) && (i!=j) ){
            106                                        if( w[i][j] > w[i][k] + w[k][j] ){
            107                                                w[i][j] = w[i][k] + w[k][j];
            108                                        }

            109                                }

            110                        }

            111                }

            112                w[k][k] = 0;
            113        }

            114
            115        scanf( "%d"&m );
            116        while( m-- ){
            117                scanf( "%s", ip );
            118                i = IpToId( ip );
            119                scanf( "%s", ip );
            120                j = IpToId( ip );
            121                printf( "%d\n", (i==0)||(j==0)||(w[i][j]==OO) ? -1 : w[i][j] );
            122        }

            123        return 0;
            124}

            125

            posted on 2012-05-14 16:08 coreBugZJ 閱讀(666) 評論(0)  編輯 收藏 引用 所屬分類: ACM 、Algorithm課內作業

            国产高潮国产高潮久久久91 | 日韩欧美亚洲综合久久影院d3| 久久精品国产AV一区二区三区| 久久亚洲AV无码精品色午夜| 亚洲国产精品成人久久| 精品精品国产自在久久高清 | 亚洲日本va午夜中文字幕久久| 久久国产亚洲精品| 久久午夜无码鲁丝片| 国产成人久久777777| 久久精品国产亚洲AV蜜臀色欲| 久久国产乱子精品免费女| 思思久久99热免费精品6| 久久99精品久久久久久hb无码| 久久久久亚洲精品无码网址 | 国产69精品久久久久久人妻精品| 久久久久久国产精品免费无码 | 欧美性大战久久久久久| 国产Av激情久久无码天堂| 中文精品99久久国产| 久久青青草原综合伊人| 日产精品99久久久久久| 一本一本久久a久久精品综合麻豆| 91精品国产高清久久久久久io | 无码人妻久久一区二区三区蜜桃| 91精品国产综合久久婷婷| 香蕉久久久久久狠狠色| 久久综合久久伊人| 久久精品成人影院| 久久不见久久见免费影院www日本| 男女久久久国产一区二区三区| 亚洲人成无码久久电影网站| 久久久久久亚洲精品不卡| 国产午夜精品久久久久九九电影| 91精品国产乱码久久久久久| 99久久精品毛片免费播放| 99久久99久久久精品齐齐| 欧美精品一区二区精品久久| 韩国免费A级毛片久久| 波多野结衣中文字幕久久| 国产午夜精品久久久久免费视|