HJ21 简单密码
描述
现在有一种密码变换算法。
九键手机键盘上的数字与字母的对应: 1–1, abc–2, def–3, ghi–4, jkl–5, mno–6, pqrs–7, tuv–8 wxyz–9, 0–0,把密码中出现的小写字母都变成九键键盘对应的数字,如:a 变成 2,x 变成 9.
而密码中出现的大写字母则变成小写之后往后移一位,如:X ,先变成小写,再往后移一位,变成了 y ,例外:Z 往后移是 a 。
数字和其它的符号都不做变换。
示例1
输入:
YUANzhi1987
输出:
zvbo9441987
法一
import java.util.*;
public class Main {
private static HashMap<String, String> hs = new HashMap<>();
static {
hs.put("1", "1");
hs.put("abc", "2");
hs.put("def", "3");
hs.put("ghi", "4");
hs.put("jkl", "5");
hs.put("mno", "6");
hs.put("pqrs", "7");
hs.put("tuv", "8");
hs.put("wxyz", "9");
hs.put("0", "0");
}
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
while (sc.hasNext()) {
String str = sc.nextLine();
char[] ch = str.toCharArray();
StringBuffer sb = new StringBuffer();
for (char c : ch) {
if (c >= '0' && c <= '9') {
sb.append(String.valueOf(c));
} else if (c >= 'A' && c <= 'Y') {
char newC = (char)(c + 32 + 1);
sb.append(String.valueOf(newC));
} else if (c == 'Z') {
sb.append('a');
} else {
Set<String> set = hs.keySet();
for (String s : set) {
if (s.contains(String.valueOf(c))) {
sb.append(hs.get(s));
}
}
}
}
System.out.println(sb.toString());
}
}
}