假设密钥为:spectacular。
明文:
a | b | c | d | e | f | g | h | i | j | k | l | m | n | o | p | q | r | s | t | u | v | w | x | y | z |
对应的密文:
s | p | e | c | t | a | u | l | r | b | d | f | g | h | i | j | k | m | n | o | q | v | w | x | y | z |
如果输入的明文为“China”,则对应的密文为“elrhs”。
代码实现中需要注意的点:
(1) 密钥,密文含有除英文字母以外的字符。
(2) 密钥含有重复字母,需要去重。
密文的生成过程:
(1)把密钥去掉重复元素之后的字符串为①。
(2)a-z字符串把去掉与①相同元素之后为②。
(3)密文为:①+②
public class Test {
static Map<Character, Character> map = new HashMap<>();
static String secretStr = "";
static Scanner sc = new Scanner(System.in);
/**
* 字符串去重
* @param str
* @return
*/
public static String removeDuplicates(String str) {
Set<Character> set = new HashSet<>();
StringBuilder stringBuilder = new StringBuilder();
for (int i = 0; i < str.length(); i++) {
char c = str.charAt(i);
if (!set.contains(c)) {
set.add(c);
stringBuilder.append(c);
}
}
return stringBuilder.toString();
}
/**
* 生成密文
* str字符串 去掉与secret相同元素
* 之后secret+str
* @param secret
* @param str
* @return
*/
public static String createSecretStr(String secret, String str) {
secretStr = "";
while (secret.length() > 0) {
for (int j = 0; j < str.length(); j++) {
if (str.charAt(j) == (secret.charAt(0))) {
secretStr += (str.charAt(j) + "");
str = str.replace(String.valueOf(str.charAt(j)), "");
secret = secret.replace(String.valueOf(secret.charAt(0)), "");
break;
}
}
}
secretStr += str;
return secretStr;
}
/**
* 判断字符串中是否含有特殊字符
* @param str
* @return
*/
public static boolean containsSpecialCharacters(String str) {
String pattern = "[a-zA-Z]";
str = str.toLowerCase(Locale.ROOT);
return !Pattern.compile(pattern).matcher(str).find();
}
/**
* 编码
*
*/
public static void encode() {
String encodeText = "";
System.out.println("请输入明文");
String next = sc.next();
boolean b = containsSpecialCharacters(next);
if (b) {
System.out.println("密钥具有非法字符。");
} else {
//把明文和密文对应放map里
for (int i = 0; i < next.length(); i++) {
encodeText += map.get(next.charAt(i));
}
System.out.println(encodeText);
}
}
/**
* 解码
*
* @param str 字符串 abcd
*/
public static void decode(String str) {
String decodeText = "";
decodeText = "";
System.out.println("请输入密文");
String next = sc.next();
boolean b = containsSpecialCharacters(next);
if (b) {
System.out.println("密钥具有非法字符。");
} else {
for (int i = 0; i < next.length(); i++) {
for (int j = 0; j < str.length(); j++) {
if (next.charAt(i) == map.get(str.charAt(j))) {
decodeText += str.charAt(j);
break;
}
}
}
}
System.out.println(decodeText);
}
public static void main(String[] args) {
String str = "abcdefghijklmnopqrstuvwxyz";
Scanner sc = new Scanner(System.in);
System.out.println("请输入密钥");
String secret = sc.next();
//调用函数 检查有没有非法字符
boolean b = containsSpecialCharacters(secret);
if (b) {
System.out.println("密钥具有非法字符。");
} else {
//有大写字母的话 转成小写字母
secret = secret.toLowerCase(Locale.ROOT);
//去重
secret = removeDuplicates(secret);
//生成密文
secretStr = createSecretStr(secret, str);
System.out.println("明文:" + str);
System.out.print("密文:");
for (int i = 0; i < 26; i++) {
map.put(str.charAt(i), secretStr.charAt(i));
System.out.print(secretStr.charAt(i));
}
System.out.println();
while (true) {
System.out.println("1,明文->密文");
System.out.println("2. 密文->明文");
System.out.println("0. 结束");
int i = sc.nextInt();
if (i == 1) {
encode();
} else if (i == 2) {
decode(str);
} else if (i == 0) {
return;
}
}
}
}
}