从零开始学Java-Day05-练习01:利用数组解决数据加密习题的过程及相关思考

数据加密问题
1、问题
   某个公司采用公用电话传递数据信息,数据是小于9位的整数,为了确保安全,在传递过程中需要加密,加密规则如下:首先将数据倒序,然后将每位数字都加上5,再用和除以10的余数代替该数字,最后将第一位和最后一位数字交换。 请任意给定一个小于9位的整数,然后,把加密后的结果在控制台打印出来。
2、难点:数据长度不固定。
3、要求(以123456为例)
(1)数据是小于8位的整数
     int number = 123456
(2)加密规则:
     a: 首先将数据逆序
                    654321
     b: 将每位数字都加上5,再用和除以10的余数代替该数字
                    109876
     c: 最后将第一位和最后一位数字交换
                    609871
(3)把加密后的结果在控制台打印出来
4、分析过程
(2)赋值数组
    可以采用for循环除10取余的方法获取每一位的数字,
    传入数组。
    代码:
  
  int[] arr = new int[8];
    int j = 1;
    for (int i = arr.length-1; i >=0; i--) {
        arr[i] = (number / j) % 10;
        j *= 10;
    }
    问题:无法确定键盘录入数据的位数。数组长度设置为最大8,
         数组中会有多余的0元素。
    解决:采用for循环找到第一个不为0的数字索引,
         设置为索引0
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值