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

            好友

            同學

            網友

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            久久久久女教师免费一区| 香港aa三级久久三级| 亚洲国产精品成人久久| 久久久久亚洲AV片无码下载蜜桃| 久久精品国产亚洲网站| 日本欧美国产精品第一页久久| 色8久久人人97超碰香蕉987| 国产福利电影一区二区三区久久久久成人精品综合 | 国产精品丝袜久久久久久不卡| 亚洲Av无码国产情品久久| 久久久久久久97| 伊人情人综合成人久久网小说| 国产麻豆精品久久一二三| 欧美亚洲国产精品久久久久| 色综合久久天天综合| 久久精品国产亚洲AV麻豆网站 | 久久精品国产一区二区电影| 久久久av波多野一区二区| 奇米影视7777久久精品人人爽 | 国产精品中文久久久久久久| 2021国产成人精品久久| 久久亚洲精品无码AV红樱桃| 亚洲伊人久久综合中文成人网| 欧美精品一区二区精品久久| 色诱久久久久综合网ywww| 狠狠色婷婷久久一区二区| 久久久黄色大片| 久久乐国产综合亚洲精品| 久久av高潮av无码av喷吹| 久久这里只有精品久久| 久久精品国产91久久麻豆自制| 99久久成人国产精品免费| 国内精品久久久久久久97牛牛| 久久久久亚洲av无码专区导航| 精品一二三区久久aaa片| 久久久久久国产精品无码下载 | 久久精品国产精品亚洲| 性欧美大战久久久久久久| 漂亮人妻被中出中文字幕久久 | 国产精品久久久久久久app| 伊人久久无码精品中文字幕|