需求:
某系统的数字密码是一个四位数,如1983,为了安全,需要加密后再传输,加密规则是:对密码中的每位数,都加5 ,再对10求余,最后将所有数字顺序反转,得到一串加密后的新数,请设计出满足本需求的加密程序!
java
import java.util.Scanner;
public class Test4 {
//完成四位数字加密
public static void main(String[] args) {
Scanner y = new Scanner(System.in);
System.out.println("请输入四位密码");
int code= y.nextInt();
//若输入的是1983的话
System.out.println("加密后的密码是"+code1(code));;
}
public static String code1(int x){
//1、首先要进行四位数字的拆分成一个一个的数字并且放进数组里
//创建了一个拆分数字放进数组的方法spli,并且使用
//直接alt+回车会直接出来此方法在底部
int arr[] = split(x);//设置一个新的数组接受返回来的数组
//{1,9,8,3}
//2、利用for循环遍历每位数字进行加密
for (int i = 0 ;i< arr.length;i++){
arr[i] = (arr[i]+5)%10;
}//输出后arr的值为[6,4,3,8]
//3、数组反转,需要定义一个新的方法进行数组反转,并且使用
fanzhuan(arr);//调用完后arr= [8,3,4,6]
//4、最后定义一个空的字符串,将反转完的数组挨个拼接打印出来
String data = " ";
for (int j =0;j<arr.length;j++){
data += arr[j];//字符串相加的话是相互拼接的
}
return data;//返回结果
}
//进行数字拆分加入数组的方法
public static int[] split(int x) {
//此题目限制于四位数,多位可以以此类推
int[] arr = new int[4];
arr[0] =x/1000;
arr[1] =(x/100)%10;
arr[2] =(x/10)%10;
arr[3] =x%10;
return arr;
}
//此处是对数组进行反转的
public static void fanzhuan(int[] arr) {//引用会改变值
//定义一个从头开始遍历的数组,在定义一个从后往前遍历的数组,两个互相交换位置
for (int i =0,j =arr.length-1;i<j;i++,j--){
//定义一个临时变量接受其中一个的值
int temp = arr[j];
arr[j] = arr[i];
arr[i] = temp;
}
}
}