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]+" ");
        }


    }
}
相关推荐
qmx_0728 分钟前
HTB-Jerry(tomcat war文件、msfvenom)
java·web安全·网络安全·tomcat
为风而战37 分钟前
IIS+Ngnix+Tomcat 部署网站 用IIS实现反向代理
java·tomcat
limingade2 小时前
手机实时提取SIM卡打电话的信令和声音-新的篇章(一、可行的方案探讨)
物联网·算法·智能手机·数据分析·信息与通信
技术无疆3 小时前
快速开发与维护:探索 AndroidAnnotations
android·java·android studio·android-studio·androidx·代码注入
jiao000014 小时前
数据结构——队列
c语言·数据结构·算法
C-SDN花园GGbond4 小时前
【探索数据结构与算法】插入排序:原理、实现与分析(图文详解)
c语言·开发语言·数据结构·排序算法
迷迭所归处5 小时前
C++ —— 关于vector
开发语言·c++·算法
架构文摘JGWZ6 小时前
Java 23 的12 个新特性!!
java·开发语言·学习
leon6256 小时前
优化算法(一)—遗传算法(Genetic Algorithm)附MATLAB程序
开发语言·算法·matlab
CV工程师小林6 小时前
【算法】BFS 系列之边权为 1 的最短路问题
数据结构·c++·算法·leetcode·宽度优先