JAVA 练习题(4)

32 篇文章 1 订阅

数字资产的概念被提出来,用于给数字资产加密的业务变得非常火热,现有一套用于给数字资产加密的系统专门用于产生加密密码,请设计一个方法用于给数字密码进行加密。

加密规则如下:根据数字长度的每位数,给每位数+5,再对10求余,最后将所有数字反转,得到的新数,如果是奇数请加上1997,否则就是这个新数。

分析:1.需要输入一个数,判断输入数字的位数

        Scanner s=new Scanner(System.in);
        System.out.println("输入密码:");
        int a=s.nextInt();//输入密码
        int f=a;
        int count=0;//定义一个计数器,计算位数
        while (f>=1){//判断位数
            f=f/10;
            count++;
        }
        System.out.println("有"+count+"位");//位数

 在这里定义了一个 f=a 是因为下面的while循环会对你输入的值a进行计算,如果没有定义这个

f=a 在后面的计算中a的值就为0.

2.对输入的数字取出每一位并进行加五模10计算,并翻转

        int v;
        int q=10;
        int sum=0;
        for (int i = 0; i <count; i++) {//a 1234
            v=(a%q+5)%10;//对输入的数进行加5模10
            sum=sum*10+v;//遍历求和得出新的数
            a=a/10;
        }
        System.out.println(sum);

 用v将每次取出的数进行计算后的值保存再用sum进行求和,而且通过这个for循环让计算后的值自动翻转。

3.判断是否为奇数,如果是奇数,就加上1997,否则不变

        if(sum%2!=0){
            sum=sum+1997;
            System.out.println("加密后新的值"+sum);
        }
        else{
            System.out.println("加密后新的值"+sum);
        }

完整代码:

import java.util.Scanner;

//需求:加密规则如下:根据数字长度的每位数,给每位数+5,再对10求余,最后将所有数字反转,得到的新数,
// 如果是奇数请加上1997,否则就是这个新数。
public class Test3{
    public static void main(String[] args) {
        jiami();
    }

    public static void jiami() {
        Scanner s=new Scanner(System.in);
        System.out.println("输入密码:");
        int a=s.nextInt();//输入密码
        int f=a;
        int count=0;
        while (f>=1){//判断位数
            f=f/10;
            count++;
        }
        System.out.println("有"+count+"位");//位数
        //int b[]=new int[count];
        int v;
        int q=10;
        int sum=0;
        for (int i = 0; i <count; i++) {//a 1234
            v=(a%q+5)%10;//对输入的数进行加5模10
            sum=sum*10+v;//遍历求和得出新的数
            a=a/10;
        }
        System.out.println(sum);
        if(sum%2!=0){
            sum=sum+1997;
            System.out.println("加密后新的值"+sum);
        }
        else{
            System.out.println("加密后新的值"+sum);
        }
    }
}

加密计算结果:

 当我们输入的数字最后一个值为5时,我们会发现结果少一位:

但是这并不影响我们,因为我们需要的只有加密,如果客户需要解密,那我们就需要增加一个数组,放在第二步里面,在第三步里面加个判断,如果翻转后的数字的位数小于原数字的位数,并且反转后的值不是偶数那就要加上1997不小于原数的位数,那就输出遍历数组b[],否则就输出sum。

 更新后代码如下:

import java.util.Scanner;

//需求:加密规则如下:根据数字长度的每位数,给每位数+5,再对10求余,最后将所有数字反转,得到的新数,
// 如果是奇数请加上1997,否则就是这个新数。
public class Test3{
    public static void main(String[] args) {
        jiami();
    }

    public static void jiami() {
        Scanner s=new Scanner(System.in);
        System.out.println("输入密码:");
        int a=s.nextInt();//输入密码
        int f=a;
        int count=0;
        while (f>=1){//判断位数
            f=f/10;
            count++;
        }
        System.out.println("有"+count+"位");//位数
        int b[]=new int[count];
        int v;
        int q=10;
        int sum=0;
        for (int i = 0; i <count; i++) {//a 1234
            v=(a%q+5)%10;//对输入的数进行加5模10
            sum=sum*10+v;//遍历求和得出新的数
            b[i]=v;
            a=a/10;
        }
        int co=0;
        int g=sum;
        int e=1;
        while (g>=1){//判断位数
            g=g/10;
            co++;
            e=10*e;
        }
        if(co<count&&sum%2==0||sum+1997<e){//位数少一位,为奇数,加上1997位数不变
            System.out.print("加密后新的值:");
            for (int m:b) {
                System.out.print(m);
            }
        }
        else if(sum%2!=0&&sum+1997>e){//为偶数,加上1997位数不变
            sum=sum+1997;
            System.out.print("加密后新的值:"+sum);
        }
        else{
            System.out.println("加密后新的值"+sum);
        }
    }
}

测试输出:

输入翻转加1997后位数不变:

 输入翻转后少一位:

 

 正常输入:

 

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值