描述
现在有一种密码变换算法。
九键手机键盘上的数字与字母的对应: 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个字符。
输出描述:
输出密码变换后的字符串
示例1
输入:
YUANzhi1987
输出:
zvbo9441987
解题思路:
第一步:建立密码数字映射;
第二步:遍历a-z 字母,放入数组中。利用索引找出对应密码字段;
const rl = require("readline").createInterface({ input: process.stdin });
var iter = rl[Symbol.asyncIterator]();
const readline = async () => (await iter.next()).value;
void async function () {
// Write your code here
const numMap = {
'abc': 2,
'def': 3,
'ghi': 4,
'jkl': 5,
'mno': 6,
'pqrs': 7,
'tuv': 8,
'wxyz': 9,
}
const letters = [] ; let result = ''
for(let i=0;i<26;i++) {
let letter = String.fromCharCode(65+i)
letters.push(letter)
}
while(line = await readline()){
for(let i=0;i<line.length;i++){
if(/[A-Z]/.test(line[i])) {
if(line[i] === 'Z') {
result = result + 'a'
} else {
const index = letters.findIndex(t => t === line[i])
result = result + letters[index+1].toLocaleLowerCase()
}
} else if (/[a-z]/.test(line[i])) {
let num
for(let key in numMap) {
if(key.includes(line[i])){
num = numMap[key]
}
}
result = result + String(num)
} else if (/[0-9]/.test(line[i])) {
result = result + String(line[i])
} else {
result = result + ''
}
}
console.log(result)
}
}()