青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

我希望你是我獨(dú)家記憶

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

PKU ——1506——(同ZJU2003)

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

 

  1 //1506 Accepted 572K 250MS C++ 3223B 
  2 
  3 //求出傳遞閉包后,a對應(yīng)的密碼的outdeg應(yīng)該為(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] ;//文本到對應(yīng)密碼的轉(zhuǎn)換
 19 int pwd2text[size] ;//密碼到對應(yīng)文本的轉(zhuǎn)換
 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++ ) ;//找到第一個(gè)不相同的字母
 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() ;//注意輸入的一個(gè)text不是一個(gè)字符串
 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     }//構(gòu)建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++ ) {//判斷是否存在孤立點(diǎn)
 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 

只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久岛国电影| 欧美三级视频在线播放| 精品福利免费观看| 亚洲精品视频免费观看| 在线天堂一区av电影| 国产精品久久午夜| 久久综合九色综合网站| 午夜一区不卡| 一区二区三区国产在线观看| 免费av成人在线| 亚洲尤物影院| 亚洲午夜极品| 亚洲精品视频一区| 亚洲国产精品va在看黑人| 国内精品久久久久影院薰衣草| 国产精品av久久久久久麻豆网| 久久综合色一综合色88| 久久久999| 六月丁香综合| 久久精品30| 欧美一区二区视频97| 国产自产精品| 欧美亚洲视频一区二区| 性欧美xxxx视频在线观看| 亚洲午夜国产成人av电影男同| 亚洲激情视频网站| 99精品欧美一区二区蜜桃免费| 亚洲人成77777在线观看网| 国产精品激情av在线播放| 校园激情久久| 美女视频一区免费观看| 欧美精品偷拍| 国产精品久久久久免费a∨大胸 | 欧美国产激情二区三区| 亚洲免费播放| 毛片基地黄久久久久久天堂| 国产精品区二区三区日本| 99国产精品私拍| 欧美黄色一区| 久久久久久国产精品一区| 国产亚洲欧洲一区高清在线观看 | 校园激情久久| 性欧美18~19sex高清播放| 欧美深夜福利| 欧美日韩免费看| 国产精品福利影院| 欧美片第一页| 国产精品福利在线观看网址| 国产麻豆一精品一av一免费| 亚洲一区二区三区免费观看 | 亚洲第一页在线| 亚洲欧美日韩天堂一区二区| 国内精品视频一区| 国产日产亚洲精品| 国产精品尤物| 亚洲国产精品激情在线观看| av不卡免费看| 老司机午夜精品| 亚洲另类在线视频| 久久国产乱子精品免费女| 欧美日韩一区二区三区在线视频 | 亚洲国产成人精品久久久国产成人一区 | 久久久久久久久久码影片| 亚洲电影第1页| 欧美一区二区精品在线| 欧美啪啪一区| 亚洲天堂成人在线视频| 欧美黑人在线观看| 亚洲精选国产| 欧美少妇一区二区| 在线日韩中文字幕| 久久人人爽国产| 亚洲福利在线视频| 另类亚洲自拍| 亚洲午夜伦理| 一区二区三区毛片| 久久午夜av| 日韩亚洲国产精品| 亚洲破处大片| 欧美日韩国产精品一区二区亚洲| 亚洲欧洲日韩女同| 欧美h视频在线| 欧美成人四级电影| 亚洲黄一区二区三区| 一区二区三区欧美成人| 欧美日韩第一页| 亚洲女人小视频在线观看| 午夜精品久久久久久久蜜桃app| 国产情侣一区| 蜜桃av噜噜一区二区三区| 欧美另类视频在线| 久久精品理论片| 欧美久久久久久久久久| 久久精品夜夜夜夜久久| 欧美韩国日本一区| 性伦欧美刺激片在线观看| 亚洲精品乱码久久久久久| 日韩亚洲视频| 国产亚洲精品久久久久动| 欧美91精品| 亚洲精品五月天| 一区二区亚洲精品国产| 国产精品99久久久久久人| 伊人久久亚洲热| 欧美亚洲三区| 亚洲一二三区精品| 欧美日韩免费观看中文| 亚洲福利视频一区| 亚洲人成高清| 99av国产精品欲麻豆| 欧美激情1区2区3区| 亚洲午夜极品| 午夜激情综合网| 一区二区国产在线观看| 久久精品综合网| 久久电影一区| 欧美激情欧美狂野欧美精品| 久久一综合视频| 国内外成人免费激情在线视频网站| 亚洲精一区二区三区| 一区二区激情视频| 欧美午夜a级限制福利片| 在线视频你懂得一区| 国产精品99免费看 | 国产午夜精品一区二区三区欧美| 亚洲美女在线看| 快射av在线播放一区| 亚洲国产精品久久| 亚洲精选视频免费看| 欧美高清视频一二三区| 亚洲国产成人精品视频| 亚洲一级二级在线| 国产一区二区三区成人欧美日韩在线观看 | 亚洲欧美日韩另类精品一区二区三区| 欧美一级播放| 91久久精品国产| 国产精品久久久久久久久久妞妞 | 亚洲欧美视频在线观看视频| 在线成人av| 亚洲人成在线观看网站高清| 亚洲欧美日韩一区在线| 亚洲精品黄网在线观看| 国产在线精品二区| 国产精品美女久久久久久久| 美女精品网站| 久久久www成人免费毛片麻豆| 99这里有精品| 亚洲国产成人不卡| 亚洲电影免费| 一本一本久久| 亚洲日本va午夜在线影院| 国产日韩亚洲欧美精品| 欧美精品日日鲁夜夜添| 久久久天天操| 久久精品导航| 欧美日本韩国一区二区三区| 99re热这里只有精品免费视频| 亚洲国产精品视频一区| 亚洲国产你懂的| 亚洲一区影院| 黄色精品网站| 国产日韩综合一区二区性色av| 亚洲一区二区三区四区中文| 最新69国产成人精品视频免费| 免费观看一区| 中文日韩在线| 欧美亚洲专区| 亚洲国产二区| 日韩视频免费| 国产精品一二三四区| 久久午夜av| 欧美日韩中文字幕在线视频| 亚洲深夜福利视频| 午夜久久tv| 亚洲免费高清视频| 亚洲午夜视频在线| 在线观看一区二区视频| 亚洲精品视频中文字幕| 国产精品大片wwwwww| 老司机aⅴ在线精品导航| 欧美日韩亚洲成人| 国产精品日韩欧美一区二区三区| 免费精品99久久国产综合精品| 女生裸体视频一区二区三区| 亚洲影视九九影院在线观看| 美女国产一区| 伊人久久婷婷| 一区二区三区国产精华| 亚洲精品美女在线观看播放| 久久九九热re6这里有精品| 亚洲综合色自拍一区| 欧美精品久久久久久| 亚洲电影av在线| 亚洲国产精品福利| 久久免费一区| 亚洲影院色在线观看免费| 久久亚洲综合| 欧美国产精品中文字幕| 在线播放一区| 免费成人高清在线视频|