java题目之数字加密以及如何解密

复制代码
public class Main6 {
    public static void main(String[] args) {
        // 某系统的数字密码(大于0),比如1983,采用加密方式进行传输

        //定义了一个静态数组

         int []arr={1,9,8,3};

        //1.加密
        //先给每位数加上5
        for (int i = 0; i <arr.length ; i++) {
            arr[i]=arr[i]+5;
        }
        //再对10取余
        for (int i = 0; i <arr.length ; i++) {
            arr[i]=arr[i]%10;
        }
        //最后将所有数反转
        for (int i = 0,j= arr.length-1; i <j ; i++,j--) {
            int temp=arr[i];
            arr[i]=arr[j];
            arr[j]=temp;
        }

        //把数组里面的每一个数字进行拼接,变成加密以后的结果
         int number=0;
        for (int i = 0; i <arr.length ; i++) {
            number=number*10+arr[i];
        }
        System.out.println(number);
    }
}

输出结果如下:

复制代码
   public static void main(String[] args) {
        //需求:
        //把整数上的每一位都添加到数组当中
        //反向推导


        //计算数组的长度
        int  number=12345;
        int temp=number;
        //定义一个变量
        int count=0;
       while(number>0) {
           number=number/10;
           count++;
       }
        //定义一个动态数组
        //动态初始化
        int []arr=new int[count];
       //把整数上的每一位都添加到数组当中
        int  index=arr.length-1;
       while(temp!=0){
           //获取temp里面的每一位数组
           int ge=temp%10;
           //再去掉右边的那位数字
           temp=temp/10;
           arr[index]=ge;
           index-- ;
       }
       //验证结果
        for (int i = 0; i <arr.length ; i++) {
            System.out.print(arr[i]+" ");
            
        }
    }
}
复制代码
    public static void main(String[] args) {
        //定义数组记录解密之后的结果
        int[]arr={8,3,4,6};

        for (int i = 0 ,j=arr.length-1; i <j ; i++,j--) {
            int temp=arr[i];
            arr[i]=arr[j];
            arr[j]=temp;
        }
        //由于加密是通过对10取余的方式进行获取的
        //所以在加密的时候就需要判断,0~4的时候之间+10 5~9之间数字不变

        for (int i = 0; i <arr.length ; i++) {
            if(0<arr[i]&& arr[i]<=4 ){
                arr[i]=arr[i]+10;
            }
        }
        //在加密的过程中每位数加上5
        //那么在解密的过程中每位数减5
        for (int i = 0; i < arr.length ; i++) {
            arr[i]=arr[i]-5;
        }

        //反转
        for (int i = 0; i <arr.length ; i++) {
            System.out.print(arr[i]+" ");
        }


    }
}
相关推荐
IT古董35 分钟前
第四章:大模型(LLM)】06.langchain原理-(3)LangChain Prompt 用法
java·人工智能·python
轻抚酸~4 小时前
小迪23年-32~40——java简单回顾
java·web安全
Sirius Wu6 小时前
Maven环境如何正确配置
java·maven
健康平安的活着6 小时前
java之 junit4单元测试Mockito的使用
java·开发语言·单元测试
No0d1es7 小时前
电子学会青少年软件编程(C/C++)5级等级考试真题试卷(2024年6月)
c语言·c++·算法·青少年编程·电子学会·五级
Java小白程序员7 小时前
Spring Framework :IoC 容器的原理与实践
java·后端·spring
xuTao6677 小时前
Easy Rules 规则引擎详解
java·easy rules
m0_480502648 小时前
Rust 入门 KV存储HashMap (十七)
java·开发语言·rust
大阳1238 小时前
线程(基本概念和相关命令)
开发语言·数据结构·经验分享·算法·线程·学习经验
杨DaB9 小时前
【SpringBoot】Swagger 接口工具
java·spring boot·后端·restful·swagger