• <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 1864 Playing With Cubes

              1/*
              2EOJ 1864 Playing With Cubes
              3
              4
              5----問題描述:
              6
              7Children are used to playing with special cubes with letters written on the cubes' faces.
              8The goal of the game is to compose words using such cubes.
              9If you want to compose the word "DOG", you must find 3 cubes, one containing the letter 'D',
             10        one containing the letter 'O', and one containing the letter 'G',
             11        and orient them so the proper letters are facing upward.
             12You are also given a some words, 
             13        each element of which contains a word that you would like to spell out using the cubes.
             14
             15
             16----輸入:
             17
             18There are several test cases,
             19each test case begins with two numbers N(1<=N<=50) and M(1<=M<=50).
             20the second line contains N string,the i-th string shows the uppercase letters(between 2 and 50,inclusive) on the i-th cube.
             21The third line contains the M words.Each element of words will contain between 2 and 50 uppercase letters, inclusive.
             22
             23
             24----輸出:
             25
             26Output the words' number that can be composed using the given cubes in ascending order.
             27If no words' number that can be composed output -1.
             28
             29
             30----樣例輸入:
             31
             325 3
             33ABCDEF DEFGHI OPQRST ZZZZZZ YYYYYY
             34CAT DOG PIZZA
             356 7
             36ABCDEF DEFGHI OPQRST MNZLSA QEIOGH IARJGS
             37DOG CAT MOUSE BIRD CHICKEN PIG ANIMAL
             38
             39
             40----樣例輸出:
             41
             421
             430 1 3 5
             44
             45
             46----分析:
             47
             48對每個 word 建立二分圖模型,
             49一邊 x[0], x[1],  x[n-1] 分別對應 word 中的每個字母,
             50一邊 y[0], y[1],  y[m-1] 分別對應每個 cube ,
             51若字母 x[i] 包含于 cube y[j] 中,則 x[i] 與 y[j] 連一條邊,
             52然后求出此二分圖最大匹配,若與 word 中字母個數相同,則輸出此 word 編號。
             53
             54求二分圖最大匹配使用匈牙利算法。
             55
             56
             57*/

             58
             59
             60#include <stdio.h>
             61#include <string.h>
             62
             63#define  L  59
             64
             65
             66/* 匈牙利算法 begin */
             67
             68int n;             /* 一邊 x[0], x[1],  x[n-1] */
             69int m;             /* 一邊 y[0], y[1],  y[m-1] */
             70int adj[ L ][ L ]; /* adj[i][j] != 0  表示 x[i] 與 y[j] 有邊 */
             71int res[ L ];      /* res[j]    != -1 表示當前與 y[j] 匹配的點為 x[res[j]] */
             72int sta[ L ];      /* sta[j]    != 0  表示 y[j] 在可增廣路中 */
             73
             74        /* 0 != find 表示找到可增廣路 */
             75int find( int i ) {
             76        int j;
             77        for ( j = 0; j < m; ++j ) {
             78                if ( adj[ i ][ j ] && (! sta[ j ]) ) {
             79                        sta[ j ] = 1;
             80                        if ( (-1 == res[ j ]) || (find(res[j])) ) {
             81                                res[ j ] = i;
             82                                return 1;
             83                        }

             84                }

             85        }

             86        return 0;
             87}

             88
             89        /* 求最大匹配 */
             90int maxMatch() {
             91        int i, ans = 0;
             92        memset( res, -1sizeof(res) );
             93        for ( i = 0; i < n; ++i ) {
             94                memset( sta, 0sizeof(sta) );
             95                if ( find(i) ) {
             96                        ++ans;
             97                }

             98        }

             99        return ans;
            100}

            101
            102/* 匈牙利算法 end */
            103
            104
            105int main() {
            106        int  tc, tw;
            107        char cube[ L ][ L ];
            108        char word[ L ];
            109        int  ans[ L ], tot;
            110        int  i, j, k;
            111        while ( 2 == scanf( "%d%d"&tc, &tw ) ) {
            112                tot = 0;
            113
            114                for ( i = 0; i < tc; ++i ) {
            115                        scanf( "%s", cube[ i ] );
            116                }

            117                for ( i = 0; i < tw; ++i ) {
            118                        scanf( "%s", word );
            119
            120                        memset( adj, 0sizeof(adj) );
            121                        n = strlen( word );
            122                        m = tc;
            123                        for ( j = 0; j < n; ++j ) {
            124                                for ( k = 0; k < m; ++k ) {
            125                                        if ( strchr( cube[ k ], word[ j ] ) != NULL ) {
            126                                                adj[ j ][ k ] = 1;
            127                                        }

            128                                }

            129                        }

            130
            131                        if ( maxMatch() == n ) {
            132                                ans[ tot++ ] = i;
            133                        }

            134                }

            135
            136                if ( 0 == tot ) {
            137                        puts( "-1" );
            138                        continue;
            139                }

            140                printf( "%d", ans[ 0 ] );
            141                for ( i = 1; i < tot; ++i ) {
            142                        printf( " %d", ans[ i ] );
            143                }

            144                puts( "" );
            145        }

            146        return 0;
            147}

            148

            posted on 2012-03-30 22:16 coreBugZJ 閱讀(750) 評論(0)  編輯 收藏 引用 所屬分類: ACMAlgorithm課內作業

            久久笫一福利免费导航| 综合人妻久久一区二区精品| 91秦先生久久久久久久| 亚洲狠狠久久综合一区77777| 国产AV影片久久久久久 | 久久精品中文字幕无码绿巨人| 日产精品久久久久久久| 久久99精品国产99久久6男男| 日本久久久久久久久久| 少妇内射兰兰久久| 国产成人精品综合久久久| 手机看片久久高清国产日韩| 成人资源影音先锋久久资源网| 欧洲国产伦久久久久久久| 国产精品久久久久9999高清| 久久无码AV中文出轨人妻| 国产L精品国产亚洲区久久| 久久久久99精品成人片试看| 亚洲一区精品伊人久久伊人| 一级做a爰片久久毛片人呢| 亚洲精品乱码久久久久久按摩| 精品久久久久久久久久久久久久久| 亚洲国产欧洲综合997久久| 青青青青久久精品国产h久久精品五福影院1421| 亚洲第一永久AV网站久久精品男人的天堂AV | 国产午夜免费高清久久影院 | 久久久精品人妻一区二区三区四 | 久久久噜噜噜www成人网| 久久久久久免费视频| 亚洲午夜福利精品久久| 欧美色综合久久久久久| 天天影视色香欲综合久久| 久久精品成人欧美大片| 精品久久久久久久久久久久久久久 | 免费观看成人久久网免费观看| 久久久久亚洲av综合波多野结衣 | 伊人精品久久久久7777| 亚洲国产一成久久精品国产成人综合| 久久免费香蕉视频| 婷婷国产天堂久久综合五月| 久久AV高潮AV无码AV|