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

            亚洲欧美一级久久精品| 久久精品国产亚洲av日韩| 久久人人爽爽爽人久久久| 久久久久久免费视频| 欧美久久综合九色综合| 色播久久人人爽人人爽人人片AV| 久久久久亚洲AV无码去区首| 久久中文字幕人妻丝袜| 日本欧美久久久久免费播放网| 日韩精品久久久久久久电影蜜臀| 久久精品国产亚洲AV电影| 国产精品一区二区久久精品无码 | 欧美牲交A欧牲交aⅴ久久| 少妇久久久久久久久久| 久久精品无码一区二区app| 亚洲精品国精品久久99热一| 久久精品国产99久久久香蕉| 国产亚洲精久久久久久无码| 久久婷婷五月综合97色直播| 久久99国产乱子伦精品免费| 午夜肉伦伦影院久久精品免费看国产一区二区三区 | 久久免费的精品国产V∧| 日韩亚洲国产综合久久久| 99久久国产综合精品网成人影院 | 人妻精品久久久久中文字幕一冢本| 国产99久久久国产精品~~牛| 人妻无码αv中文字幕久久| 久久AV高清无码| 久久精品国产亚洲αv忘忧草 | 久久av无码专区亚洲av桃花岛| 精产国品久久一二三产区区别| 久久精品国产精品亜洲毛片| 欧洲性大片xxxxx久久久| 久久综合偷偷噜噜噜色| 久久精品国产亚洲AV不卡| 欧美大香线蕉线伊人久久| 久久精品成人免费看| 久久国产精品二国产精品| 久久精品国产亚洲7777| 久久综合给合久久狠狠狠97色| 91精品国产综合久久久久久|