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

            好友

            同學

            網友

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            国内精品久久久久久久coent| 久久国产精品久久| 久久久久久综合一区中文字幕| 夜夜亚洲天天久久| 色天使久久综合网天天| 9久久9久久精品| 久久九九免费高清视频| 久久狠狠高潮亚洲精品| 亚洲精品乱码久久久久久不卡| 精品久久久久久国产91| 久久精品国产精品亚洲下载 | 久久午夜夜伦鲁鲁片免费无码影视| 四虎影视久久久免费| 久久国产免费观看精品3| 久久国产成人精品国产成人亚洲| 久久久久高潮综合影院| 亚洲国产成人久久综合一区77| 午夜精品久久久久久久久| 久久只有这里有精品4| 欧美激情精品久久久久久久九九九 | 久久久久久久综合狠狠综合| 精品999久久久久久中文字幕| 伊人色综合久久天天人守人婷| 久久最新精品国产| 久久精品一本到99热免费| 狠狠色丁香婷婷久久综合五月| 久久AAAA片一区二区| 91精品国产91久久久久久青草| 亚洲人成伊人成综合网久久久 | 国产成人香蕉久久久久| 久久99热狠狠色精品一区| 久久久久亚洲AV无码观看| 久久人人青草97香蕉| 久久久久亚洲AV综合波多野结衣 | 亚洲欧美成人综合久久久| 伊人 久久 精品| 久久久久国产精品嫩草影院| 日韩欧美亚洲综合久久 | 亚洲αv久久久噜噜噜噜噜| 久久天天婷婷五月俺也去| 欧美激情一区二区久久久|