• <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 閱讀(2333) 評論(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年3月>
            26272829123
            45678910
            11121314151617
            18192021222324
            25262728293031
            1234567

            導航

            統計

            公告

            常用鏈接

            留言簿(3)

            隨筆分類

            隨筆檔案

            me

            好友

            同學

            網友

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            久久97久久97精品免视看秋霞| 精品久久久久久成人AV| 97r久久精品国产99国产精| 少妇人妻综合久久中文字幕| 久久精品夜色噜噜亚洲A∨| 久久se精品一区二区| 欧美伊香蕉久久综合类网站| 国产成人久久激情91| 成人免费网站久久久| 久久天堂电影网| 国产精品久久久久…| 欧美精品一区二区精品久久| 国产叼嘿久久精品久久| 久久亚洲中文字幕精品一区| 999久久久国产精品| 久久国产视频99电影| 亚洲精品tv久久久久久久久久| 日批日出水久久亚洲精品tv| 欧美亚洲国产精品久久| 久久久噜噜噜久久熟女AA片| 久久亚洲国产中v天仙www| 久久国产乱子伦精品免费午夜| 久久久亚洲裙底偷窥综合 | 久久久国产精品亚洲一区| 2022年国产精品久久久久| 久久99精品国产麻豆蜜芽| 国产免费久久精品99re丫y| 精品熟女少妇AV免费久久| 精品久久香蕉国产线看观看亚洲| 97精品久久天干天天天按摩| 久久精品国产只有精品66 | 久久久久国产| 亚洲精品乱码久久久久久自慰| 中文字幕一区二区三区久久网站| 日韩va亚洲va欧美va久久| 久久国产色AV免费观看| 久久久久久A亚洲欧洲AV冫| 伊人久久大香线焦AV综合影院| 国内精品伊人久久久久AV影院| 久久露脸国产精品| 97久久精品人妻人人搡人人玩 |