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;
...
把JiaMIDemo的代码改进一下:
A:把数据改进皱键盘录入
B:把代码改进为方法实现
另一个数据测试:
number:1234567
第一步:7654321
第二步:2109876
第三步:6109872
知识点:
变量 
数据类型
运算符
键盘录入
语句for循环
方法
数组
*/
import java.util.Scanner;
class JiaMiDemo3{
public static void main(String[] args){
//创建键盘录入对像
Scanner sc = new Scanner(System.in);

//请输入一个数据
System.out.print("请输入一个数据(小于8位):");
int number = sc.nextInt();//1234567

//写功能实现把number进行加密
//调用
String result = JiaMi(number);
System.out.println("加密后为:"+result);
}
/*
需求:写一个功能,把数据number进行加密码。
两个明确:
返回值类型:String 做一个字符串拼接。
参数列表:int number
*/
public static String JiaMi(int number){
//定义数组
int[] arr = new int[8];

//定义索引
int index = 0;

//把number中的数据放到数组中
/*
number: 1 2 3 4 5 6 7 
index: 0 1 2 3 4 5 6 
*/
//第一步:7654321
/*
arr[0] = 1234567除10余7 arr[index索引0] = 7
*/
while(number > 0){//1234567>0
arr[index] = number%10;//1234567除10余7 arr[index索引0] = 7, 123456除10余6 arr[index(索引1)] = 6, 12345除10余5 arr[index(索引2)] = 5, 1234除10余4 arr[index(索引3)] = 4, 123除10余3 arr[index(索引4)] = 3, 12除10余2 arr[index(索引5)] = 2, 1除10余1 arr[index(索引6)] = 1
/*
index: 0 1 2 3 4 5 6 
number: 7 6
*/
index++;//0+0=0, 0 + 1 = 1, 1 + 1 = 2, 2+1=3, 3+1=4, 4+1=5, 5+1=5
number/=10;//1234567除10等于number=123456余7, 123456除10等于number=12345余6, 12345除10等于number=1234余5, 1234除10等于number=123余4, 123除10等于number=12余3, 12除10等于number=1余2, 1除10等于number=0余1
}

//把数据加5,然后对10取得余数
/*
number: 7 6 5 4 3 2 1
index: 0 1 2 3 4 5 6 
*/
//第二步:2109876
for(int x = 0;x<index;x++){//0<7654321
//arr[x] = arr[x] + 5
arr[x] +=5;//arr[x(索引0也就是7+5=12)] = arr[x(索引0也就是7)] + 5,
//arr[x] = arr[x] / 10
arr[x] %=10;//arr[索引0也就是12/10=1.2] = arr[索引0也就是12] / 10
}

//把第一位和最后一位交换
//第三步:6109872
int temp = arr[0];
arr[0] = arr[index-1];
arr[index-1] = temp;

//把数组的元素拼接成一个字符串返回 
//定义一个内容空字符串
//第三步:6109872
String s = "";
for(int x=0;x<index;x++){
s+=arr[x];//s = s + arr[0]= 6...
}
return s;//return 6 1
}
}
1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。、可私 6信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 、可私信6博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 、可私信6博主看论文后选择购买源代码。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值