JAVA思维提升案例3

需求:

某系统的数字密码是一个四位数,如1983,为了安全,需要加密后再传输,加密规则是:对密码中的每位数,都加5 ,再对10求余,最后将所有数字顺序反转,得到一串加密后的新数,请设计出满足本需求的加密程序!

java 复制代码
import java.util.Scanner;

public class Test4 {
    //完成四位数字加密
    public static void main(String[] args) {
        Scanner y = new Scanner(System.in);
        System.out.println("请输入四位密码");
        int code= y.nextInt();
        //若输入的是1983的话
        System.out.println("加密后的密码是"+code1(code));;
    }
    public static String code1(int x){
        //1、首先要进行四位数字的拆分成一个一个的数字并且放进数组里
        //创建了一个拆分数字放进数组的方法spli,并且使用
        //直接alt+回车会直接出来此方法在底部
        int arr[] = split(x);//设置一个新的数组接受返回来的数组
        //{1,9,8,3}
        //2、利用for循环遍历每位数字进行加密
        for (int i = 0 ;i< arr.length;i++){
            arr[i] = (arr[i]+5)%10;
        }//输出后arr的值为[6,4,3,8]
        //3、数组反转,需要定义一个新的方法进行数组反转,并且使用
        fanzhuan(arr);//调用完后arr= [8,3,4,6]
        //4、最后定义一个空的字符串,将反转完的数组挨个拼接打印出来
        String data = " ";
        for (int j =0;j<arr.length;j++){
            data += arr[j];//字符串相加的话是相互拼接的
        }
        return data;//返回结果
    }
    //进行数字拆分加入数组的方法
   public static int[] split(int x) {
        //此题目限制于四位数,多位可以以此类推
        int[] arr = new int[4];
       arr[0] =x/1000;
        arr[1] =(x/100)%10;
        arr[2] =(x/10)%10;
        arr[3] =x%10;
        return arr;
    }
    //此处是对数组进行反转的
    public static void fanzhuan(int[] arr) {//引用会改变值

        //定义一个从头开始遍历的数组,在定义一个从后往前遍历的数组,两个互相交换位置
        for (int i =0,j =arr.length-1;i<j;i++,j--){
            //定义一个临时变量接受其中一个的值
            int temp = arr[j];
            arr[j] = arr[i];
            arr[i] = temp;
        }

    }
}
相关推荐
Bellafu6661 小时前
spring项目部署后为什么会生成 logback-spring.xml文件
java
递归不收敛1 小时前
一、Java 基础入门:从 0 到 1 认识 Java(详细笔记)
java·开发语言·笔记
沐浴露z1 小时前
【Java SpringAI智能体开发学习 | 2】SpringAI 实用特性:自定义Advisor,结构化输出,对话记忆持久化,prompt模板,多模态
java·spring·springai
小沈同学呀2 小时前
创建一个Spring Boot Starter风格的Basic认证SDK
java·spring boot·后端
码农小伙2 小时前
通俗易懂地讲解JAVA的BIO、NIO、AIO
java·nio
不要再敲了3 小时前
JDBC从入门到面试:全面掌握Java数据库连接技术
java·数据库·面试
潇I洒3 小时前
若依4.8.1打包war后在Tomcat无法运行,404报错的一个解决方法
java·tomcat·ruoyi·若依·404
Funcy4 小时前
XxlJob 源码分析05:执行器注册流程
java
Boop_wu4 小时前
[数据结构] 队列 (Queue)
java·jvm·算法
无敌的神原秋人4 小时前
关于Redis不同序列化压缩性能的对比
java·redis·缓存