华为OD机试 2024E卷题库疯狂收录中,刷题 <a rel="nofollow" href="https://blog.csdn.net/qq_40374604/category_12822407.html" style="color: red;">点这里</a>。

专栏导读

本专栏收录于 《华为OD机试(JAVA)真题(E卷+D卷+A卷+B卷+C卷)》

刷的越多,抽中的概率越大,私信javapub,备注华为OD,加入华为OD刷题交流群,每一题都有详细的答题思路、详细的代码注释、3个测试用例、为什么这道题采用XX算法、XX算法的适用场景,发现新题目,随时更新,全天CSDN在线答疑。


简单密码

现在有一种密码变换算法。九键手机键盘上的数字与字母的对应关系如下:

  • 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

Java 编程

javapackage cn.net.javapub.demo2.demo;

/**
 * @author: shiyuwang
 * @url: http://javapub.net.cn
 */

import java.util.*;

public class Main {
    //定义map容器存储按键对应数字字符的容器
    private static Map<String, String> map = new HashMap<>();

    //静态初始化、加载map容器
    static {
        map.put("1", "1");
        map.put("abc", "2");
        map.put("def", "3");
        map.put("ghi", "4");
        map.put("jkl", "5");
        map.put("mno", "6");
        map.put("pqrs", "7");
        map.put("tuv", "8");
        map.put("wxyz", "9");
        map.put("0", "0");
    }

    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        while (scanner.hasNext()) {
            String str = scanner.nextLine();
            char[] chars = str.toCharArray();
            //构造buffer容器存储转换后的字符串
            StringBuffer buffer = new StringBuffer();
            for (char c : chars) {
                //如果是正整数则不需要进行加密
                if (c >= '0' && c <= '9') {
                    buffer.append(String.valueOf(c));
                } else if (c >= 'A' && c <= 'Y') { //如果是A~Y的大写字母则需要将其+32位转换成小写再向后移1位
                    char newChar = (char) (c + 32 + 1);
                    buffer.append(String.valueOf(newChar));
                } else if (c == 'Z') { //如果是Z则加密成a
                    buffer.append("a");
                } else {
                    //去除map容器中的key与字符进行校验并加密
                    Set<String> keys = map.keySet();
                    for (String k : keys) {
                        if (k.contains(String.valueOf(c)))
                            buffer.append(map.get(k));
                    }
                }
            }
            System.out.print(buffer.toString());
        }
    }
}

展示效果:

在这里插入图片描述

🏆下一篇: 华为OD机试 - 密码验证合格程序 (Java 2024 E卷 100分) 🏆本文收录于, 搬砖工逆袭Java架构师

刷的越多,抽中的概率越大,私信javapub,备注华为OD,加入华为OD刷题交流群,每一题都有详细的答题思路、详细的代码注释、3个测试用例、为什么这道题采用XX算法、XX算法的适用场景,发现新题目,随时更新,全天CSDN在线答疑。