1002—列变位法解密

列变位法解密

Accepts: 1393

Submissions: 5460

Time Limit: 2000/1000 MS (Java/Others)

Memory Limit: 65536/65536 K (Java/Others)

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行

第一行,一个字符串s(1≤|s|≤1e5),表示经过列变位法加密后的密文

第二行,一个整数K(1≤K≤|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

解题思路: 直接模拟,可能会超时!

import java.util.Scanner;

public class Main1
{
	public static void main(String[] args)
	{
		Scanner sc = new Scanner(System.in);
		int T = sc.nextInt();

		for (int cas = 1; cas <= T; cas++)
		{
		sc.nextLine();
		String str = sc.nextLine();
		int mi = sc.nextInt();
		char c1[][] = null;
		if (str.length() % mi == 0)  c1 = new char[str.length()/mi][mi];
		else c1 = new char[str.length()/mi+1][mi];
		if (str.length() % mi != 0)
		{
			for (int i = 0; i < mi-str.length()%mi; i++)
			{
				c1[c1.length-1][mi-1-i] = 20;
			}
		}
		for (int i = 0, k = 0; i < c1[0].length; i++)
		{
			for (int j = 0; j < c1.length; j++)
			{
				if (c1[j][i] == 20)continue;
				c1[j][i] = str.charAt(k++);
			}
		}
		System.out.println("Case #"+cas+":");
		for (int i = 0; i < c1.length; i++)
		{
			for (int j = 0; j < c1[i].length; j++)
			{
				if (c1[i][j] == 20) break;
				System.out.print(c1[i][j]);
			}
		}
		System.out.println();
	  }

	}
}
时间: 2024-11-06 17:46:07

1002—列变位法解密的相关文章

字符串处理 2015百度之星资格赛 1002 列变位法解密

题目传送门 1 /* 2 字符串处理:要求解码,然而二维数组开不下,可以直接输出 3 只要在余数的地方判断一下就行了,vector的效率不高 4 另外:感觉麻烦的地方应该纸上写写就清楚了 5 */ 6 #include <cstdio> 7 #include <iostream> 8 #include <algorithm> 9 #include <cstring> 10 #include <string> 11 #include <cma

字符串处理 百度之星资格赛 1002 列变位法解密

题目传送门 1 /* 2 字符串处理:要求解码,然而二维数组开不下,可以直接输出 3 只要在余数的地方判断一下就行了,vector的效率不高 4 */ 5 #include <cstdio> 6 #include <iostream> 7 #include <algorithm> 8 #include <cstring> 9 #include <string> 10 #include <cmath> 11 using namespac

ACM学习历程—BestCoder 2015百度之星资格赛1002 列变位法解密(vector容器)

Problem Description 列变位法是古典密码算法中变位加密的一种方法,具体过程如下 将明文字符分割成个数固定的分组(如5个一组,5即为密钥),按一组一行的次序整齐排列,最后不足一组不放置任何字符,完成后按列读取即成密文. 比如: 原文:123456789 密钥:4 变换后的矩阵: 1234 5678 9xxx (最后的几个x表示无任何字符,不是空格,不是制表符,就没有任何字符,下同) 密文:159263748 再比如: 原文:Hello, welcome to my dream w

2015百度之星资格赛1002列变位法解密

Accepts: 1124 Submissions: 4157 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others) Problem Description 列变位法是古典密码算法中变位加密的一种方法,具体过程如下 将明文字符分割成个数固定的分组(如5个一组,5即为密钥),按一组一行的次序整齐排列,最后不足一组不放置任何字符,完成后按列读取即成密文. 比如: 原文:123456789 密钥

bestcoder 1002 列变位法解密(模拟)

Problem Description 列变位法是古典密码算法中变位加密的一种方法,具体过程如下 将明文字符分割成个数固定的分组(如5个一组,5即为密钥),按一组一行的次序整齐排列,最后不足一组不放置任何字符,完成后按列读取即成密文. 比如: 原文:123456789 密钥:4 变换后的矩阵: [pre]1234 5678 9xxx[/pre] (最后的几个x表示无任何字符,不是空格,不是制表符,就没有任何字符,下同) 密文:159263748 再比如: 原文:Hello, welcome to

HDU 百度之星(测试赛) - 1002 列变位法解密

Problem Description 列变位法是古典密码算法中变位加密的一种方法,具体过程如下将明文字符分割成个数固定的分组(如5个一组,5即为密钥),按一组一行的次序整齐排列,最后不足一组不放置任何字符,完成后按列读取即成密文. 比如: 原文:123456789 密钥:4 变换后的矩阵: 1234 5678 9xxx (最后的几个x表示无任何字符,不是空格,不是制表符,就没有任何字符,下同) 密文:159263748 再比如: 原文:Hello, welcome to my dream wo

1002列变位法解密

1 /* 2 3 Time 124MS 4 5 Memory 1504 6 7 */ 8 #include<iostream> 9 #include<climits> 10 #include <cstring> 11 #include <cstdlib> 12 #define WORDS "Case #" 13 #define ELSE ":\n" 14 #define MAX 100010 15 using name

百度之星资格赛--列变位法解密

列变位法解密 Accepts: 867 Submissions: 3035 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others) Problem Description 列变位法是古典密码算法中变位加密的一种方法,具体过程如下 将明文字符分割成个数固定的分组(如5个一组,5即为密钥),按一组一行的次序整齐排列,最后不足一组不放置任何字符,完成后按列读取即成密文. 比如: 原文:123456

2015百度之星 列变位法解密

列变位法解密 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others) Problem Description 列变位法是古典密码算法中变位加密的一种方法,具体过程如下 将明文字符分割成个数固定的分组(如5个一组,5即为密钥),按一组一行的次序整齐排列,**最后不足一组不放置任何字符**,完成后按列读取即成密文. 比如: 原文:123456789 密钥:4 变换后的矩阵: [pre]1234