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


    }
}
相关推荐
東隅已逝,桑榆非晚1 分钟前
深⼊理解指针(5)
c语言·笔记·算法
Gerardisite1 分钟前
企业微信客户管理系统实战:标签、分层与自动化流程搭建
java·python·机器人·自动化·企业微信
ch.ju5 分钟前
Java程序设计(第3版)第三章——数组的定义方式
java·开发语言
lwf0061645 分钟前
顺序模型学习日记
算法
_日拱一卒9 分钟前
LeetCode:199二叉树的右视图
算法·leetcode·职场和发展
The Chosen One98516 分钟前
分享对dp题目的理解-不断更新ing
笔记·算法·深度优先·动态规划·dp
有时间要学习20 分钟前
【无标题】
算法
Chloeis Syntax20 分钟前
JavaEE学习日记(2)---文件操作和IO
java·笔记·学习·java-ee
无风听海21 分钟前
OAuth 2.0 response_type完全指南
java·开发语言·oauth
re林檎21 分钟前
算法札记——5.15
算法