【问题描述】有一种加密方法为:其使用一个字母串(可以含重复字母,字母个数不超过50)作为密钥。假定密钥单词串为feather,则先去掉密钥单词中的重复字母得到单词串feathr,然后将其反序,并将字母表中的其它字母以反序追加到后面:
r | h | t | a | e | f | z | y | x | w | v | u | s | q | p | o | n | m | l | k | j | i | g | d | c | b |
加密字母的对应关系如下:
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 |
r | h | t | a | e | f | z | y | x | w | v | u | s | q | p | o | n | m | l | k | j | i | g | d | c | b |
其中第一行为原始英文字母,第二行为对应加密字母。其它字符不进行加密。编写一个程序,用这种密码加密输入的字符串。假定输入的待加密字符串中的字母全为小写字母,并且输入密钥也全为小写字母。
【输入形式】从标准输入中输入密钥串,然后在下一行输入要加密的字符串。密钥串字母个数不超过50个,待加密字符串的字符数不超过100个。
【输出形式】加密后结果输出到标准输出。
【样例输入】
feather
c language is wonderful.
【样例输出】t urqzjrze xl gpqaemfju.
【样例说明】首先将给定的密钥单词去除重复字母并反序,然后按照上面的加密对应表对后面的内容进行加密即可得到加密后的字符串,其中只对英文字母进行加密对换,并且假设英文字母全是小写字母。
参考代码:
import java.io.IOException;
import java.util.ArrayList;
import java.util.LinkedHashMap;
import java.util.LinkedHashSet;
import java.util.Map;
import java.util.Scanner;
import java.util.Set;
public class Main {
public static void main(String[] args) throws IOException {
Scanner sc = new Scanner(System.in);
String k=sc.nextLine();
String s=sc.nextLine();
Set<Character> word1 = new LinkedHashSet<Character>();
Set<Character> word = new LinkedHashSet<Character>();
for(int i=0;i<k.length();i++) {
word1.add(k.charAt(i));
}
String s1="";
for(Character m:word1) {s1+=m;}
for(int num=s1.length()-1;num>=0;num--) {
word.add(s1.charAt(num));
}
for(char ch='z';ch>='a';ch--) {
word.add(ch);
}
Map<Character, Character> pat = new LinkedHashMap<Character, Character>();
ArrayList<Character> h = new ArrayList<Character>();
for(Character d:word) {
h.add(d);
}
for(int i=0;i<26;i++) {
char ch = (char)('a'+i);
pat.put(ch, h.get(i));
}
for(int j=0;j<s.length();j++) {
if(Character.isLowerCase(s.charAt(j))) {
System.out.print(pat.get(s.charAt(j)));
}
else {
System.out.print(s.charAt(j));
}
}
}
}