某系统的数字密码是一个四位数,如1983,为了安全,需要加密后再传输,加密规则是:对密码中的每位数,都加5 ,再对10求余,最后将所有数字顺序反转,得到一串加密后的新数,请设计出满足本需求的加密程序!
1、数组元素的反转、交换是如何完成的?
反转数组,就是对数组中的元素,按照前后位置,依次交换数据。
2、如果一个方法里要做的事情比较多,我们在开发中一般会怎么做?
一般会把多个事情拆成多个方法去完成,也就是将独立功能独立成一个方法。
package com.itheima.question;
import java.util.Scanner;
public class Question4 {
public static void main(String[] args) {
System.out.println("4567加密后的密码是:"+encryp(4567));
}
/**
* 对密码进行加盐加密
*
* @param password 要加密的数字密码(四位数)
* @return 加密之后的数组密码(四位数)
*/
public static int encryp(int password) {
int firstNumber = password / 1000 % 10;
int secondNumber = password / 100 % 10;
int thirdNumber = password / 10 % 10;
int fourNumber = password % 10;
firstNumber = (firstNumber + 5) % 10;
secondNumber = (secondNumber + 5) % 10;
thirdNumber = (thirdNumber + 5) % 10;
fourNumber = (fourNumber + 5) % 10;
return fourNumber*1000+thirdNumber*100+secondNumber*10+firstNumber;
}
}