• <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 閱讀(660) 評論(0)  編輯 收藏 引用 所屬分類: ACMAlgorithm課內作業

            嫩草影院久久国产精品| 久久人爽人人爽人人片AV | 久久免费精品一区二区| 亚洲va久久久噜噜噜久久狠狠| 久久久久久久国产免费看| 国产99久久久国产精免费| 久久久不卡国产精品一区二区| 国产精品永久久久久久久久久 | 久久久久久久综合日本| 久久国产精品免费一区| 蜜桃麻豆www久久国产精品| 亚洲а∨天堂久久精品| 久久国语露脸国产精品电影| 狠狠色狠狠色综合久久| 国内精品久久久久久久97牛牛| 91久久婷婷国产综合精品青草| 日韩亚洲欧美久久久www综合网 | 久久99免费视频| 久久国产午夜精品一区二区三区| 久久艹国产| 一本色道久久综合狠狠躁| 久久精品毛片免费观看| 久久国产精品一区| 亚洲中文字幕无码久久2020| 精品久久久久久无码中文字幕一区| 久久最近最新中文字幕大全| 亚洲国产精品无码久久九九| 久久久久99精品成人片试看| 精品免费久久久久国产一区| 亚洲综合精品香蕉久久网| 国产高清美女一级a毛片久久w| 日本WV一本一道久久香蕉| 日本久久久精品中文字幕| 久久人人爽人人爽人人片av麻烦| 99久久超碰中文字幕伊人| 久久亚洲国产成人影院网站| 久久久久99精品成人片直播| 伊人久久一区二区三区无码| 久久精品国产99国产精偷| 久久久无码精品亚洲日韩蜜臀浪潮| 久久午夜电影网|