【百度之星資格賽】 1002 列變位法解密

Problem Description

列變位法是古典密碼算法中變位加密的一種方法,具體過程如下 將明文字符分割成個數固定的分組(如5個一組,5即爲密鑰),按一組一行的次序整齊排列,最後不足一組不放置任何字符,完成後按列讀取即成密文。

比如:

原文:123456789

密鑰:4

變換後的矩陣:

1234
5678
9xxx

(最後的幾個x表示無任何字符,不是空格,不是製表符,就沒有任何字符,下同)

密文:159263748

再比如:

原文:Hello, welcome to my dream world!

密鑰:7

變換後的矩陣:

Hello,
welcome
 to my 
dream w
orld!xx

密文:

Hw doeetrrlloellc adoomm!,my e w

實現一個利用列變位法的加密器對Bob來說輕而易舉,可是,對Bob來說,想清楚如何寫一個相應的解密器似乎有點困難,你能幫幫他嗎?

Input

第一行一個整數T,表示T組數據。

每組數據包含2

第一行,一個字符串s1|s|1e5,表示經過列變位法加密後的密文

第二行,一個整數K1K|s|,表示原文在使用列變位法加密時的密鑰

輸入保證密文字符串中只含有ASCII碼在[0x20,0x7F)範圍內的字符

Output

對於每組數據,先輸出一行

Case #i:

然後輸出一行,包含一個字符串s_decrypt,表示解密後得到的明文

Sample Input
4
159263748
4
Hw doeetrrlloellc adoomm!,my  e w
7
Toodming is best
16
sokaisan
1
Sample Output
Case #1:
123456789
Case #2:
Hello, welcome to my dream world!
Case #3:
Toodming is best
Case #4:
sokaisan


#include<stdlib.h>
#include<string.h>
#include<stdio.h>

int main()
{
    int T,cnt=1;
    scanf("%d", &T);
    getchar();
    while(T--){
            printf("Case #%d:\n", cnt++);
        char str[100005]={0};
        int k, roww, row=0, col, colremain;
        gets(str);
        int str_len = strlen(str);
        scanf("%d", &k);
        getchar();
        roww = str_len / k;
        if(str_len % k) row =roww + 1;
        else row = roww;
        col = str_len % k;
        colremain = k - col;

        for(int i=1; i<= row; ++i)
        {
            for(int j=0; j<=col; ++j)
            {
                if(str[i+j*row-1] == NULL) break;
                printf("%c", str[i+j*row-1]);
                str[i+j*row-1] = NULL;
            }
            for(int j=1; j<colremain&&(row*col+j*roww)<str_len;j++)
            {
                if(str[i-1+row*col+j*roww] == NULL) break;
                printf("%c", str[i-1+row*col+j*roww]);
                str[i-1+row*col+j*roww]=NULL;
            }
        }
        printf("\n");
    }
    return 0;
}

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章