一、题目描述
现在有一种密码变换算法。
九键手机键盘上的数字与字母的对应: 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个字符。
三、输出描述
输出密码变换后的字符串。
四、解题思路
- 读取输入的密码字符串;
- 创建一个字符数组 a,用于存储九键手机键盘上数字与字母的对应关系;
- 创建一个 StringBuilder 对象 sb,用于存储转换后的密码字符串;
- 遍历输入的密码字符串,对每个字符进行如下操作:
- 如果字符是大写字母(A 到 Z),将其转换为小写字母,并往后移一位;如果移动后的字符超出小写字母范围,则循环回到 a;
- 如果字符是小写字母(a 到 z),根据九键手机键盘上的对应关系将其转换为相应的数字;
- 其他情况下,字符保持不变;
九键手机密码变换算法 - 华为OD机试题解析
这篇博客详细介绍了华为在线测评(OD)中的一道简单密码变换题目。题目要求根据九键手机键盘数字与字母的对应关系,将输入的密码字符串中的小写字母转化为数字,大写字母转化为小写并后移一位(Z转为a)。博客提供了解题思路和Java实现代码,最终展示了密码变换的效果。
订阅专栏 解锁全文
5485

被折叠的 条评论
为什么被折叠?



