Java加密问题的的_实现

/*
某个公司采用公用电话传递数据信息,数据是小于8位的整数,为了确保安全,
在传递过程中需要加密,加密规则如下:
首先将数据倒序,然后将每位数字都加上5,再用和除以10的余数代替该数字,
最后将第一位和最后一位数字交换。请任意给定一个小于8整数,
然后,把加密后的结果在控制台打印出来。
题目要求:
A:数据是小于8位的整数
定义一个int类型的数据
int munber = 123456;
B:加密规则
a:首先将数据倒序
结果 6,5,4,3,2,1
b:然后将每位数字都加上5,再用和除以10的余数代替该数字
结果 109876
c:将最后一位和最后一位数字交换。请任意给定一个小于8整数
结果 609871
C:把加密结果输出在控制台

通过简单分析,我们知道如果我们有办法把这个数据变成数组就好了。
不是直接写成这个样子的:
int[] arr = {1,2,3,4,5,6};
如何把数据转成数组呢?
A:定义一个数据
int number = 123456;
B:定义一个数组,问题来了,数组长度是多少呢?
int[] arr = new int[8];//不可能超过8
在赋值的时候,用一个变量记录索引变化。
定义一个索引值0
int index = 0;
C:获取每一个数据
int ge = number%10;
int shi = number/10%10;
int bai = number/10/10%10;

arr[index] = ge;
index++;
arr[index] = shi;
index++;
arr[index] = bai;
...
*/
class JiaMiDemo{
public static void main(String[] args){
//定义一个数据
int number = 123456;//609871

//定义一个数组
int[] arr = new int[8];

//把数据中每一位上的数据获取后存储到数组中
/*
int index = 0;
arr[index] = number%10;//arr[0]=6
index++;
arr[index] = number/10%10;//arr[1]=5
index++;
arr[index] = number/10/10%10;//arr[2]=4
...
*/

//通过观察这个代码,我们发现应该是可以通过循环改进的
int index = 0;

while(number>0){//number=123456,number=12345,number=1234,number=123,number=12,number=1,number=0;
arr[index] = number%10;//arr[0]=6,arr[1]=5,arr[2]=4,arr[3]=3,arr[4]=2,arr[5]=1
index++;//index=1,index=2,index3,index=4,index=5,index=6
number/=10;//number=12345,number=1234,number=123,number=12,number=1,number=0
};

//将每位数字都加上5,再用和除以10的余数代替该数字
for(int x = 0;x<index;x++){
arr[x] +=5;
arr[x] %=10;
}

//将第一位和最后一位数字交换
int temp = arr[0];
arr[0] = arr[index-1];
arr[index-1] = temp;

//输出数据
for(int x = 0;x<index;x++){
System.out.print(arr[x]);
}
System.out.println();

}
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值