【算法】数据加密问题

题目

某个公司采用公用电话传递数据信息,数据是小于8位的整数,为了确保安全,在传递过程中需要加密,加密规则如下:首先将数据倒序,然后将每位数字都加上5,再用和除以10的余数代替该数字,最后将第一位和最后一位数字交换。 请任意键盘录入一个小于8位的整数,然后,把加密后的结果在控制台打印出来。

分析

  • 数据是小于8位的整数
    定义一个int类型的数据
    int number = 1234567;
  • 加密规则
    • 首先将数据倒序
      结果 7654321
    • 然后将每位数字都加上5,再用和除以10的余数代替该数字
      结果 2109876
    • 最后将第一位和最后一位数字交换
      结果 6109872
    • 把加密后的结果输出在控制台

通过简单的分析,我们知道如果我们有办法把这个数据变成数组就好了。
不是直接写成这个样子的:int[] arr = {1,2,3,4,5,6,7};

如何把数据转成数组呢?

  • 定义一个数据
    int number = 123456;

  • 定义一个数组,这个时候问题就来了,数组的长度是多少呢?
    int[] arr = new int[8]; //不可能超过8

  • 在赋值的时候,我用一个变量记录索引的变化。
    定义一个索引值是0
    int index = 0;

  • 获取每一个数据
    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;

 import java.util.Scanner;

class JiaMiDemo2 
{
	public static void main(String[] args) 
{
		//创建键盘录入对象
		Scanner sc = new Scanner(System.in);
		
		//请输入一个数据
		System.out.println("请输入一个数据(小于8位):");
		int number = sc.nextInt();
		
		//写功能实现把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中的数据想办法放到数组中
		while(number > 0) 
{
			arr[index] = number%10;
			index++;
			number /= 10;
		}
		
		//把每个数据加5,然后对10取得余数
		for(int x=0; x

你可能感兴趣的:(算法)