• <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>

            我希望你是我獨家記憶

            一段永遠封存的記憶,隨風而去
            posts - 263, comments - 31, trackbacks - 0, articles - 3
               :: 首頁 :: 新隨筆 ::  :: 聚合  :: 管理

            PKU ——1506——(同ZJU2003)

            Posted on 2008-08-19 19:49 Hero 閱讀(272) 評論(0)  編輯 收藏 引用 所屬分類: 代碼如詩--ACM

             

              1 //1506 Accepted 572K 250MS C++ 3223B 
              2 
              3 //求出傳遞閉包后,a對應的密碼的outdeg應該為(inn-1),b->(inn-2)
              4 //然后用pwd2word[]建立映射
              5 
              6 //以后注意特殊數(shù)據(jù)--比如要解密的單詞中根本沒有加密的字母
              7 
              8 #include <stdio.h>
              9 #include <stdlib.h>
             10 #include <string.h>
             11 
             12 const int size = 300 ;
             13 
             14 int edge[size][size] ;
             15 int indeg[size] ;
             16 int outdeg[size] ;
             17 
             18 int text2pwd[size] ;//文本到對應密碼的轉換
             19 int pwd2text[size] ;//密碼到對應文本的轉換
             20 
             21 char fword[300000] ; char sword[300000] ;
             22 int flen = 0 ; int slen = 0 ;
             23 
             24 int inn, inp, testnum ;
             25 
             26 bool can = true ;
             27 
             28 void input()
             29 {
             30     memset( edge, 0sizeof(edge) ) ;
             31 
             32     scanf( "%d %d"&inn, &inp ) ;
             33 
             34     scanf( "%s", fword ) ;
             35     forint i=2; i<=inp; i++ ) {
             36         scanf( "%s", sword ) ;
             37         flen = strlen( fword ) ; slen = strlen( sword ) ;
             38         int k = 0 ;    for( k=0; fword[k]==sword[k]&&k<slen&&k<flen; k++ ) ;//找到第一個不相同的字母
             39         if( k < flen && k < slen ) {
             40             edge[fword[k]-'a'+1][sword[k]-'a'+1= 1 ;//建圖
             41         }
             42         strcpy( fword, sword ) ;
             43     }
             44     //scanf( "%s", fword ) ;//最惡心的數(shù)據(jù)輸入(At the next line is encrypted message.)
             45     getchar() ;//注意輸入的一個text不是一個字符串
             46     gets( fword ) ;//別忘了getchar() ;
             47 }
             48 
             49 void f_indeg()
             50 {
             51     memset( indeg, 0sizeof(indeg) ) ;
             52     forint sn=1; sn<=inn; sn++ ) {
             53         forint en=1; en<=inn; en++ ) {
             54             if( edge[en][sn] ) indeg[sn]++ ;
             55         }
             56         edge[sn][sn] = 0 ;
             57     }//構建indeg[]入度
             58 }
             59 
             60 void f_outdeg()
             61 {
             62     memset( outdeg, 0sizeof(outdeg) ) ;
             63     forint sn=1; sn<=inn; sn++ ) {
             64         forint en=1; en<=inn; en++ ) {
             65             if( sn!=en&&edge[sn][en] ) outdeg[sn]++ ;
             66         }
             67     }
             68 }
             69 
             70 void process()
             71 {
             72 
             73     bool haspwd = false ;
             74     flen = strlen( fword ) ;
             75     forint i=0; i<flen; i++) {//判斷是否真的加密了--沒有也過了
             76         if( fword[i]>='a'&&fword[i]<'a'+inn ) { haspwd = true ; break ; }
             77     }
             78     if!haspwd ) { printf( "%s\n", fword ) ; return ; }
             79 
             80     forint k=1; k<=inn; k++ ) {//求傳遞閉包
             81         forint i=1; i<=inn; i++ ) {
             82             forint j=1; j<=inn; j++ ) {
             83                 if( edge[i][k] && edge[k][j] ) {
             84                     edge[i][j] = 1 ; 
             85                 }
             86             }
             87         }
             88     }
             89 
             90     can = true ;//假定可以解密
             91     forint i=1; i<=inn; i++ )    {//判斷是否存在環(huán)
             92         if( edge[i][i] ) { can = false ; break ; }
             93     }
             94     forint i=1; i<=inn; i++ ) {//判斷是否存在孤立點
             95         if!can )    break ;
             96         forint j=1; j<=inn; j++ ) {
             97             if( i == j )    continue ;
             98             if0==edge[i][j]&&0==edge[j][i] )
             99             { can = false ; break ; }
            100         }
            101     }
            102 
            103     if!can ) { printf( "Message cannot be decrypted.\n" ) ; return ; }
            104 
            105     f_outdeg() ;
            106 
            107     memset( text2pwd, -1sizeof(text2pwd) ) ;
            108     memset( pwd2text, -1sizeof(pwd2text) ) ;
            109 
            110     forint i=1; i<=inn; i++ ) {//建立文本和密文的相互映射
            111         int cnt = 0 ; int num = 0 ;
            112         forint k=1; k<=inn; k++ ) if( (inn-i)==outdeg[k] ) { cnt++ ; num=k ; }
            113         if1 == cnt ) { text2pwd[i] = num ; pwd2text[num] = i ; }
            114     }
            115 
            116     flen = strlen( fword ) ; 
            117     forint i=0; i<flen; i++ )
            118     {
            119         if( fword[i]>='a'&&fword[i]<'a'+inn )
            120         {
            121             int curnode = fword[i] - 'a' + 1 ;
            122             if( pwd2text[curnode]<0 ) { can = falsebreak ; }
            123             fword[i] = pwd2text[curnode] + 'a' - 1 ;
            124         }
            125     }
            126 
            127     if( can )    printf( "%s\n", fword ) ;
            128     else    printf( "Message cannot be decrypted.\n" ) ;
            129 }
            130 
            131 
            132 int main()
            133 {
            134     //while( scanf( "%d", &testnum ) != EOF )
            135     scanf( "%d"&testnum ) ;
            136     {
            137         forint ct=1; ct<=testnum; ct++ )
            138         {
            139             input() ;
            140 
            141             process() ;
            142 
            143             //output() ;
            144         }//for(ct)
            145     }//while
            146 
            147     return 0 ;
            148 }
            149 
            久久精品男人影院| 亚洲欧美成人久久综合中文网| 欧美午夜A∨大片久久 | 久久国产精品二国产精品 | 中文字幕精品久久久久人妻| 97久久精品无码一区二区| 久久午夜伦鲁片免费无码| 国产精品久久久久久久久免费| 超级碰久久免费公开视频| 香港aa三级久久三级老师2021国产三级精品三级在 | 久久天天躁狠狠躁夜夜96流白浆| 九九99精品久久久久久| 久久亚洲视频| 国产精品久久久天天影视| 模特私拍国产精品久久| 国产 亚洲 欧美 另类 久久| 99久久99久久精品国产片果冻| 国产精品青草久久久久福利99| 久久亚洲日韩看片无码| 国产精品xxxx国产喷水亚洲国产精品无码久久一区 | 99精品久久精品| 77777亚洲午夜久久多喷| 精品久久久久久国产三级| 久久久一本精品99久久精品66| 日韩美女18网站久久精品| 国内精品久久久久久久影视麻豆| 无码AV波多野结衣久久| 久久人人爽人人爽人人片av麻烦| 久久国产精品久久精品国产| 日产精品久久久久久久性色| 看全色黄大色大片免费久久久| 一本伊大人香蕉久久网手机| 久久国产热精品波多野结衣AV| 中文字幕无码精品亚洲资源网久久| 久久伊人五月天论坛| 久久久久国产亚洲AV麻豆| 久久精品国产一区二区三区 | 一本久久综合亚洲鲁鲁五月天| 久久国产成人| 日韩久久无码免费毛片软件| 四虎国产精品免费久久|