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

            POJ百練 - 2818:密碼

            鏈接:http://poj.grids.cn/practice/2818
            這其實就是一個簡單的移位密碼算法題,只是多了個循環而已,密碼學里面也指出過循環運算是沒有效果的,所以題目估計也就考察了這一點,如果沒有找出循環周期,此題會一直超時的...
            剛開始,我就直接模擬K次加密,顯然超時了,當時還不信了,以為簡單至此。。。
            后面我就開始改進了,剛開始是把周期計算和加密放在一起寫了,樣例也過了,但是還是一直錯...
            沒辦法再改,我改成把周期求出來,再對加密次數K取模后,再進行運算...
            好吧,還是一樣wa,后面就變成PE了。。。
            最后,這個題經過我近2個小時的奮戰,終于過了,一共錯了近10次吧...第一次提交是距現在1個多小時前了...
            最后發現錯誤的原因還是換行輸出的地方錯了,題目要求是每一組中間有個空行,我則輸出的是每次計算后有個空行...
            實在無語...
            思維不嚴謹啊...

            代碼:
            #include <stdio.h>
            #include <string.h>
            #define N_MAX 200 + 10
            int main()
            {
                int nN = 0;
                int nNArr[N_MAX];//密鑰
                int nK = 0;
                char szMsg[N_MAX];
                char szMsgBckup[N_MAX];//字符串備份
                int nCir[N_MAX];//周期
                int nMsgLen = 0;
                int nPos = 0;
                int i, j;
                
                while (scanf("%d", &nN), nN != 0)
                {
                    for (i = 1; i <= nN; ++i)
                    {
                        scanf("%d", &nNArr[i]);
                    }
                    
                    for (i = 1; i <= nN; ++i)//計算周期
                    {
                        nPos = i;
                        for (j = 1; ; ++j)
                        {
                            nPos = nNArr[nPos];
                            if (nPos == i)
                            {
                                nCir[i] = j;
                                break;
                            }
                        }
                    }
                    
                    while (scanf("%d", &nK), nK != 0)
                    {
                        getchar();//銷掉空格
                        gets(szMsg + 1);
                        nMsgLen = strlen(szMsg + 1);
                        for (i = nMsgLen; i < nN; ++i)
                        {
                            szMsg[1 + i] = ' ';
                        }
                        szMsg[1 + nN] = '\0';
                        strcpy(szMsgBckup + 1, szMsg + 1);
                        
                        for (i = 1; i <= nN; ++i)
                        {
                            nPos = i;
                            int nTimes = nK % nCir[i];
                            for (j = 1; j <= nTimes; ++j)
                            {
                                nPos = nNArr[nPos];
                            }
                            szMsg[nPos] = szMsgBckup[i];
                        }
                        
                        printf("%s\n", szMsg + 1);
                    }
                    printf("\n");
                }
                
                return 0;
            }

            posted on 2011-11-10 20:56 yx 閱讀(2353) 評論(4)  編輯 收藏 引用 所屬分類: 解題報告字符串

            評論

            # re: POJ百練 - 2818:密碼 2011-11-10 23:44 Glueless full lace wigs for black women

            相當精辟,收藏  回復  更多評論   

            # re: POJ百練 - 3724:unix紀元[未登錄] 2012-05-14 21:45 King

            。。。。。  回復  更多評論   

            # re: POJ百練 - 2818:密碼 2012-07-25 11:55

            printf("%s\n", szMsg + 1);
            是什么意思,為什么要+1?  回復  更多評論   

            # re: POJ百練 - 2818:密碼 2012-07-25 22:42 遠行

            時間比較久,忘記題目了。。。@諾
              回復  更多評論   

            <2012年9月>
            2627282930311
            2345678
            9101112131415
            16171819202122
            23242526272829
            30123456

            導航

            統計

            公告

            常用鏈接

            留言簿(3)

            隨筆分類

            隨筆檔案

            me

            好友

            同學

            網友

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            久久精品综合一区二区三区| 久久综合九色综合精品| 亚洲午夜久久久久久久久久| 国内精品久久久久影院薰衣草| 亚洲欧洲日产国码无码久久99| 国产婷婷成人久久Av免费高清| 99久久国产免费福利| 色综合久久88色综合天天 | 2021国产精品午夜久久| 99久久做夜夜爱天天做精品| 久久婷婷久久一区二区三区| 久久久这里只有精品加勒比| 久久er国产精品免费观看2| 久久91精品国产91久| 国产L精品国产亚洲区久久| 色天使久久综合网天天| 久久精品国产亚洲AV电影| 97精品伊人久久久大香线蕉| 国产精品xxxx国产喷水亚洲国产精品无码久久一区 | 久久青草国产手机看片福利盒子| AAA级久久久精品无码片| 久久丫精品国产亚洲av| 91精品国产综合久久婷婷| 国内精品久久人妻互换| 91久久婷婷国产综合精品青草| 免费观看久久精彩视频| 久久精品国产99久久香蕉| 精品人妻伦一二三区久久| 久久这里的只有是精品23| 一本色道久久88—综合亚洲精品| 色综合久久综合中文综合网| 国内精品久久久久伊人av| 狠狠久久综合| 久久久久亚洲av无码专区喷水 | 91精品国产高清久久久久久国产嫩草 | 一本大道加勒比久久综合| 久久天天日天天操综合伊人av| 亚洲午夜久久久久妓女影院 | 国产成人精品久久二区二区| 中文字幕一区二区三区久久网站| 亚洲精品乱码久久久久久蜜桃 |