一、题目描述
现在有一种密码变换算法。
九键手机键盘上的数字与字母的对应: 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≤n≤100
二、输入描述
输入一组密码,长度不超过100个字符。
三、输出描述
输出密码变换后的字符串。
四、Java算法源码
public static void main(String[] args) throws IOException {
BufferedReader bf = new BufferedReader(new InputStreamReader(System.in));
String s;
char[] a = {'2', '2', '2', '3', '3', '3', '4', '4', '4', '5', '5', '5',
'6', '6', '6', '7', '7', '7', '7', '8', '8', '8', '9', '9', '9', '9'};
while ((s = bf.readLine()) != null) {
StringBuilder sb = new StringBuilder();
for (int i = 0; i < s.length(); i++) {
char c = s.charAt(i);
//直接使用if else判断
if (c >= 'A' && c <= 'Z') {
c += 33;
//判断是否需要循环
if (c > 'z') {
c -= 26;
}
} else if (c >= 'a' && c <= 'z') {
c = a[c - 'a'];
}
sb.append(c);
}
System.out.println(sb.toString());
}
}
五、效果展示
🏆本文收录于,华为OD机试2023(Java)
本专栏包含了最新最全的2023年华为OD机试真题,有详细的分析和Java解答。已帮助1000+同学顺利通过OD机考。专栏会持续更新,每天在线答疑。