• <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 已棄。

            POJ 1603 Risk

              1/*
              2POJ 1603 Risk
              3
              4
              5----問題描述:
              6
              7Risk is a board game in which several opposing players attempt to conquer the world. The gameboard consists of a world map broken up into hypothetical countries. During a player's turn, armies stationed in one country are only allowed to attack only countries with which they share a common border. Upon conquest of that country, the armies may move into the newly conquered country. 
              8
              9During the course of play, a player often engages in a sequence of conquests with the goal of transferring a large mass of armies from some starting country to a destination country. Typically, one chooses the intervening countries so as to minimize the total number of countries that need to be conquered. Given a description of the gameboard with 20 countries each with between 1 and 19 connections to other countries, your task is to write a function that takes a starting country and a destination country and computes the minimum number of countries that must be conquered to reach the destination. You do not need to output the sequence of countries, just the number of countries to be conquered including the destination. For example, if starting and destination countries are neighbors, then your program should return one. 
             10
             11The following connection diagram illustrates the first sample input. 
             12
             13
             14----輸入:
             15
             16Input to your program will consist of a series of country configuration test sets. Each test set will consist of a board description on lines 1 through 19. The representation avoids listing every national boundary twice by only listing the fact that country I borders country J when I < J. Thus, the Ith line, where I is less than 20, contains an integer X indicating how many "higher-numbered" countries share borders with country I, then X distinct integers J greater than I and not exceeding 20, each describing a boundary between countries I and J. Line 20 of the test set contains a single integer (1 <= N <= 100) indicating the number of country pairs that follow. The next N lines each contain exactly two integers (1 <= A,B <= 20; A!=B) indicating the starting and ending countries for a possible conquest. 
             17
             18There can be multiple test sets in the input file; your program should continue reading and processing until reaching the end of file. There will be at least one path between any two given countries in every country configuration.
             19
             20
             21----輸出:
             22
             23For each input set, your program should print the following message "Test Set #T" where T is the number of the test set starting with 1. The next NT lines each will contain the result for the corresponding test in the test set - that is, the minimum number of countries to conquer. The test result line should contain the start country code A the string " to " the destination country code B ; the string ": " and a single integer indicating the minimum number of moves required to traverse from country A to country B in the test set. Following all result lines of each input set, your program should print a single blank line.
             24
             25
             26----樣例輸入:
             27
             281 3
             292 3 4
             303 4 5 6
             311 6
             321 7
             332 12 13
             341 8
             352 9 10
             361 11
             371 11
             382 12 17
             391 14
             402 14 15
             412 15 16
             421 16
             431 19
             442 18 19
             451 20
             461 20
             475
             481 20
             492 9
             5019 5
             5118 19
             5216 20
             53
             54
             55----樣例輸出:
             56
             57Test Set #1
             581 to 20: 7
             592 to 9: 5
             6019 to 5: 6
             6118 to 19: 2
             6216 to 20: 2
             63
             64
             65----分析:
             66
             67Floyd 算法。
             68
             69
             70*/

             71
             72
             73#include <stdio.h>
             74#include <string.h>
             75
             76#define  N    23
             77#define  INF  0x3F3F3F3F
             78
             79int main() {
             80        int n, w[ N ][ N ], i, j, k, td = 0;
             81        while ( 1 == scanf( "%d"&k ) ) {
             82                memset( w, 0x3Fsizeof(w) );
             83                for ( i = 0; i < k; ++i ) {
             84                        scanf( "%d"&j );
             85                        w[ 1 ][ j ] = w[ j ][ 1 ] = 1;
             86                }

             87                for ( i = 2; i <= 19++i ) {
             88                        scanf( "%d"&k );
             89                        while ( 0 < k-- ) {
             90                                scanf( "%d"&j );
             91                                w[ i ][ j ] = w[ j ][ i ] = 1;
             92                        }

             93                }

             94
             95                for ( k = 1; k <= 20++k ) {
             96                        for ( i = 1; i <= 20++i ) {
             97                                for ( j = 1; j <= 20++j ) {
             98                                        if ( (i != j) && (i != k) && (k != j) ) {
             99                                                if ( w[ i ][ j ] > w[ i ][ k ] + w[ k ][ j ] ) {
            100                                                        w[ i ][ j ] = w[ i ][ k ] + w[ k ][ j ];
            101                                                }

            102                                        }

            103                                }

            104                        }

            105                }

            106
            107                scanf( "%d"&n );
            108                printf( "Test Set #%d\n"++td );
            109                while ( 0 < n-- ) {
            110                        scanf( "%d%d"&i, &j );
            111                        printf( "%d to %d: %d\n", i, j, w[ i ][ j ] );
            112                }

            113                printf( "\n" );
            114        }

            115        return 0;
            116}

            117

            posted on 2012-05-14 16:13 coreBugZJ 閱讀(614) 評論(0)  編輯 收藏 引用 所屬分類: ACMAlgorithm課內作業

            91亚洲国产成人久久精品| 94久久国产乱子伦精品免费| 久久亚洲精品无码aⅴ大香| 国产亚洲美女精品久久久2020| 婷婷久久香蕉五月综合加勒比| 欧美一区二区精品久久| 久久久精品人妻无码专区不卡| 亚洲午夜久久久影院| 曰曰摸天天摸人人看久久久| 亚洲综合日韩久久成人AV| 精品国产综合区久久久久久| 性做久久久久久久| 天堂无码久久综合东京热| 久久综合综合久久狠狠狠97色88| 色综合久久天天综线观看| 久久av无码专区亚洲av桃花岛| 久久国产综合精品五月天| 狠狠干狠狠久久| 久久夜色精品国产网站| 欧美成人免费观看久久| 精品国产91久久久久久久a| MM131亚洲国产美女久久| 热99RE久久精品这里都是精品免费 | 欧美国产精品久久高清| 国产成人久久精品激情| 伊人久久大香线蕉精品不卡| 国产精品久久久久乳精品爆| 国产午夜久久影院| 久久精品国产亚洲AV麻豆网站| 中文字幕久久精品无码| 亚洲人成网站999久久久综合| 免费一级欧美大片久久网| 国产精品综合久久第一页| 91麻豆精品国产91久久久久久| 久久精品一区二区国产| 香蕉久久夜色精品升级完成| 热re99久久精品国99热| 1000部精品久久久久久久久| 青青草原综合久久大伊人精品| 91性高湖久久久久| 久久久久国产|