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

            我希望你是我獨家記憶

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

            ZJU——2003——(傳遞閉包+出度)

            Posted on 2008-08-19 19:27 Hero 閱讀(140) 評論(0)  編輯 收藏 引用 所屬分類: 代碼如詩--ACM
            //Accepted 2003 C++ 00:00.46 1344K 

            //求出傳遞閉包后,a對應(yīng)的密碼的outdeg應(yīng)該為(inn-1),b->(inn-2)
            //然后用pwd2word[]建立映射

            #include 
            <stdio.h>
            #include 
            <stdlib.h>
            #include 
            <string.h>

            const int size = 300 ;

            int edge[size][size] ;
            int indeg[size] ;
            int outdeg[size] ;

            int text2pwd[size] ;//文本到對應(yīng)密碼的轉(zhuǎn)換
            int pwd2text[size] ;//密碼到對應(yīng)文本的轉(zhuǎn)換

            char fword[300000] ; char sword[300000] ;
            int flen = 0 ; int slen = 0 ;

            int inn, inp, testnum ;

            bool can = true ;

            void input()
            {
                memset( edge, 
            0sizeof(edge) ) ;

                scanf( 
            "%d %d"&inn, &inp ) ;

                scanf( 
            "%s", fword ) ;
                
            forint i=2; i<=inp; i++ ) {
                    scanf( 
            "%s", sword ) ;
                    flen 
            = strlen( fword ) ; slen = strlen( sword ) ;
                    
            int k = 0 ;    for( k=0; fword[k]==sword[k]&&k<slen&&k<flen; k++ ) ;//找到第一個不相同的字母
                    if( k < flen && k < slen ) {
                        edge[fword[k]
            -'a'+1][sword[k]-'a'+1= 1 ;//建圖
                    }
                    strcpy( fword, sword ) ;
                }
                
            //scanf( "%s", fword ) ;//最惡心的數(shù)據(jù)輸入(At the next line is encrypted message.)
                getchar() ;//注意輸入的一個text不是一個字符串
                gets( fword ) ;//別忘了getchar() ;
            }

            void f_indeg()
            {
                memset( indeg, 
            0sizeof(indeg) ) ;
                
            forint sn=1; sn<=inn; sn++ ) {
                    
            forint en=1; en<=inn; en++ ) {
                        
            if( edge[en][sn] ) indeg[sn]++ ;
                    }
                    edge[sn][sn] 
            = 0 ;
                }
            //構(gòu)建indeg[]入度
            }

            void f_outdeg()
            {
                memset( outdeg, 
            0sizeof(outdeg) ) ;
                
            forint sn=1; sn<=inn; sn++ ) {
                    
            forint en=1; en<=inn; en++ ) {
                        
            if( sn!=en&&edge[sn][en] ) outdeg[sn]++ ;
                    }
                }
            }

            void process()
            {
                
            forint k=1; k<=inn; k++ ) {//求傳遞閉包
                    forint i=1; i<=inn; i++ ) {
                        
            forint j=1; j<=inn; j++ ) {
                            
            if( edge[i][k] && edge[k][j] ) {
                                edge[i][j] 
            = 1 ; 
                            }
                        }
                    }
                }

                
            int cnt = 0 ;
                
            forint i=1; i<=inn; i++ ) {
                    cnt 
            = 0 ;//計算i的入度
                    forint j=1; j<=inn; j++ ) {
                        
            if( i == j )    continue ;
                        
            if( edge[i][j] ) cnt++ ;
                        
            if0==edge[i][j]&&0==edge[j][i] ) {//存在孤立點
                            cnt = -1 ; break ;
                        }
                    }
                    
            if-1 == cnt ) pwd2text[i] = -1 ;
                    
            else pwd2text[i] = inn - cnt ;
                }

                flen 
            = strlen( fword ) ; int i = 0 ;
                
            for( i=0; i<flen; i++ )
                {
                    
            if( fword[i]>='a'&&fword[i]<'a'+inn ) {
                        
            int curnode = fword[i] - 'a' + 1 ;
                        
            if-1 != pwd2text[curnode] )
                        fword[i] 
            = pwd2text[curnode] + 'a' - 1 ;
                        
            else break ;
                    }
                }

                
            if( i == flen ) printf( "%s\n", fword ) ;
                
            else printf( "Message cannot be decrypted.\n" ) ;
            }


            int main()
            {
                
            //while( scanf( "%d", &testnum ) != EOF )
                scanf( "%d"&testnum ) ;
                {
                    
            forint ct=1; ct<=testnum; ct++ )
                    {
                        input() ;

                        process() ;

                        
            //output() ;
                    }//for(ct)
                }//while

                
            return 0 ;
            }
            国产精品美女久久久| 久久国产成人| 国产一区二区精品久久凹凸| 久久人搡人人玩人妻精品首页| 色欲综合久久躁天天躁| 国产精品美女久久久久久2018| 国产成人久久精品二区三区| 热99RE久久精品这里都是精品免费 | 久久综合狠狠综合久久激情 | 性做久久久久久久久| 成人久久精品一区二区三区| 伊人久久亚洲综合影院| 99热成人精品免费久久| 久久精品无码专区免费青青| 亚洲欧洲精品成人久久曰影片| 久久99毛片免费观看不卡| 国产亚洲美女精品久久久2020| 欧美日韩中文字幕久久伊人| 亚洲熟妇无码另类久久久| 精品久久久久久国产免费了| 国产精品久久一区二区三区| 人人狠狠综合久久88成人| 成人综合久久精品色婷婷| 久久中文精品无码中文字幕 | 久久婷婷五月综合色99啪ak| 久久久久国产一级毛片高清版| 久久久久久精品无码人妻| 欧美久久亚洲精品| 欧美精品一区二区久久| 久久综合久久性久99毛片| 久久久综合香蕉尹人综合网| 中文精品久久久久国产网址| 91精品国产色综久久| 国产精品九九久久精品女同亚洲欧美日韩综合区 | 国产精品亚洲美女久久久| 国产 亚洲 欧美 另类 久久| 久久久久一区二区三区| 嫩草影院久久国产精品| 一本大道加勒比久久综合| 久久精品成人| 久久亚洲精品无码aⅴ大香|