• <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課內作業

            7777精品伊人久久久大香线蕉| 久久久噜噜噜久久中文福利| 亚洲国产成人久久精品影视| 日本久久久精品中文字幕| 久久高潮一级毛片免费| 大香伊人久久精品一区二区| 久久久久久久久久久久中文字幕| 久久电影网一区| 2021国产精品午夜久久| 久久精品国产亚洲77777| 久久国产精品视频| 无码AV波多野结衣久久| 成人国内精品久久久久影院VR| 久久精品国产久精国产果冻传媒 | 亚洲AV日韩精品久久久久久久| 日本欧美久久久久免费播放网| 久久99精品久久久久久水蜜桃| 久久无码专区国产精品发布| 国产精品久久精品| 久久久久青草线蕉综合超碰| 欧美久久综合九色综合| 青草影院天堂男人久久| 久久精品国产亚洲AV大全| 国产精品久久久久免费a∨| 久久毛片免费看一区二区三区| 久久久久久综合一区中文字幕 | 精品久久久中文字幕人妻| 久久er国产精品免费观看8| 精品精品国产自在久久高清| 人妻精品久久久久中文字幕69| 色8激情欧美成人久久综合电| 国产精品成人无码久久久久久 | 久久久久亚洲av综合波多野结衣| 久久久久国产精品麻豆AR影院| 国产精品欧美久久久天天影视| 熟妇人妻久久中文字幕| 久久久久久精品免费免费自慰| 亚洲精品国产第一综合99久久| 国产精品99久久久精品无码| 亚洲欧洲中文日韩久久AV乱码| 亚洲欧美精品一区久久中文字幕|