• <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久久伊人精品综合观看| 亚洲精品成人网久久久久久| 精品国产一区二区三区久久久狼 | 久久婷婷人人澡人人爽人人爱| 精产国品久久一二三产区区别| 久久精品中文字幕无码绿巨人| 久久久久综合网久久| 久久无码一区二区三区少妇| 人妻精品久久久久中文字幕69 | 久久婷婷五月综合国产尤物app| 国产成人久久激情91| 亚洲人成无码www久久久| 久久婷婷五月综合色高清| 欧美午夜A∨大片久久| 国产精品99久久久久久人| 一本一道久久a久久精品综合| 久久亚洲精品中文字幕三区| 久久强奷乱码老熟女网站| 91久久精品视频| 91精品国产综合久久精品| 伊人久久大香线蕉综合影院首页| 久久99精品久久久久久秒播| 人妻久久久一区二区三区| 精品国产乱码久久久久久呢| 大香伊人久久精品一区二区| 久久精品亚洲福利| 精品久久人人妻人人做精品| 青青草原综合久久| 国产成人久久激情91| 久久无码av三级| 99久久99久久久精品齐齐| 亚洲午夜无码久久久久| 无码国内精品久久人妻麻豆按摩 | 97久久超碰国产精品2021| 无码专区久久综合久中文字幕| 久久久久久精品成人免费图片| 日产久久强奸免费的看| 婷婷国产天堂久久综合五月| 亚洲国产一成久久精品国产成人综合| 久久午夜综合久久| 怡红院日本一道日本久久|