zoukankan      html  css  js  c++  java
  • java笔试之简单密码

    密码是我们生活中非常重要的东东,我们的那么一点不能说的秘密就全靠它了。哇哈哈. 接下来渊子要在密码之上再加一套密码,虽然简单但也安全。

    假设渊子原来一个BBS上的密码为zvbo9441987,为了方便记忆,他通过一种算法把这个密码变换成YUANzhi1987,这个密码是他的名字和出生年份,怎么忘都忘不了,而且可以明目张胆地放在显眼的地方而不被别人知道真正的密码。

    他是这么变换的,大家都知道手机上的字母: 1--1, abc--2, def--3, ghi--4, jkl--5, mno--6, pqrs--7, tuv--8 wxyz--9, 0--0,就这么简单,渊子把密码中出现的小写字母都变成对应的数字,数字和其他的符号都不做变换, 

    声明:密码中没有空格,而密码中出现的大写字母则变成小写之后往后移一位,如:X,先变成小写,再往后移一位,不就是y了嘛,简单吧。记住,z往后移是a哦。

    可以用if判断,也可以用正则匹配

    package test;
    
    import java.util.Scanner;
    
    public class exam13 {
        public static void main(String[] args) {
            Scanner scanner = new Scanner(System.in);
            while (scanner.hasNext()) {
                String str = scanner.nextLine();
                // char[] pwd = str.toCharArray();
    //            System.out.println(truepwd(str).toString());
                System.out.println(truepwd2(str));
            }
            scanner.close();
        }
    
        // 方法1:if判断
        public static StringBuilder truepwd(String str) {
            StringBuilder sbBuilder = new StringBuilder();
            for (int i = 0; i < str.length(); i++) {
                char ch = str.charAt(i);
                if (ch >= 'A' && ch < 'Z') {
                    ch = (char) (ch + 1 - ('A' - 'a'));
                } else if (ch == 'Z') {
                    ch = 'a';
                } else if (ch >= 'a' && ch <= 'z') {
                    if (ch == 'a' || ch == 'b' | ch == 'c') {
                        ch = '2';
                    } else if (ch == 'd' || ch == 'e' || ch == 'f') {
                        ch = '3';
                    } else if (ch == 'g' || ch == 'h' || ch == 'i') {
                        ch = '4';
                    } else if (ch == 'j' || ch == 'k' || ch == 'l') {
                        ch = '5';
                    } else if (ch == 'm' || ch == 'n' || ch == 'o') {
                        ch = '6';
                    } else if (ch == 'p' || ch == 'q' || ch == 'r' || ch == 's') {
                        ch = '7';
                    } else if (ch == 't' || ch == 'u' || ch == 'v') {
                        ch = '8';
                    } else if (ch == 'w' || ch == 'x' || ch == 'y' || ch == 'z') {
                        ch = '9';
                    }
                }
                sbBuilder.append(ch);
            }
            return sbBuilder;
        }
    
        // 方法2:使用正则表达式
        public static String truepwd2(String str) {
            StringBuffer sBuffer = new StringBuffer(str);
            for (int i = 0; i < str.length(); i++) {
                char ch = sBuffer.charAt(i);
                if (ch >= 'A' && ch < 'Z') {
                    ch = (char) (ch + 1 - ('A' - 'a'));
                } else if (ch == 'Z') {
                    ch = 'a';
                } else if (ch >= 'a' && ch <= 'z') {
                    if (String.valueOf(ch).matches("[abc]")) {
                        ch = '2';
                    } else if (String.valueOf(ch).matches("[def]")) {
                        ch = '3';
                    } else if (String.valueOf(ch).matches("[ghi]")) {
                        ch = '4';
                    } else if (String.valueOf(ch).matches("[jkl]")) {
                        ch = '5';
                    } else if (String.valueOf(ch).matches("[mno]")) {
                        ch = '6';
                    } else if (String.valueOf(ch).matches("[pqrs]")) {
                        ch = '7';
                    } else if (String.valueOf(ch).matches("[tuv]")) {
                        ch = '8';
                    } else if (String.valueOf(ch).matches("[wxyz]")) {
                        ch = '9';
                    }
                }
                sBuffer.setCharAt(i, ch);
            }
            return sBuffer.toString();
        }
    
    }
  • 相关阅读:
    linux基础学习-6.4-Linux无法上网排查流程
    [JSOI2007][BZOJ1029] 建筑抢修
    [HNOI2003][BZOJ1216] 操作系统
    [Apio2009][BZOJ1179] Atm
    [Tjoi2013][BZOJ3172] 单词
    AC自动机学习笔记
    [转]一个比较通俗的KMP算法讲解
    [HAOI2008][BZOJ1042] 硬币购物
    [NOI2007][BZOJ1491] 社交网络
    [SCOI2009][BZOJ1295] 最长距离
  • 原文地址:https://www.cnblogs.com/bella-young/p/6410237.html
Copyright © 2011-2022 走看看