第26题自己也能实现加密(位运算)

Posted 小虚竹

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了第26题自己也能实现加密(位运算)相关的知识,希望对你有一定的参考价值。

文章目录

零、前言

​ 今天是学习 JAVA语言 打卡的第26天,每天我会提供一篇文章供群成员阅读( 不需要订阅付钱 ),读完文章之后,按解题思路,自己再实现一遍。在小虚竹JAVA社区 中对应的 【打卡贴】打卡,今天的任务就算完成了。

​ 因为大家都在一起学习同一篇文章,所以有什么问题都可以在群里问,群里的小伙伴可以迅速地帮到你,一个人可以走得很快,一群人可以走得很远,有一起学习交流的战友,是多么幸运的事情。

​ 学完后,自己写篇学习报告的博客,可以发布到小虚竹JAVA社区 ,供学弟学妹们参考。

​ 我的学习策略很简单,题海策略+ 费曼学习法。如果能把这100题都认认真真自己实现一遍,那意味着 JAVA语言 已经筑基成功了。后面的进阶学习,可以继续跟着我,一起走向架构师之路。

一、题目描述

题目: 通过位运算的异或运算符“^”,把字符串与一个指定的值进行异或运算,从而改变字符串中每个字符的值,这样就可以得到一个加密后的字符串。

二、解题思路

1、异或运算。

2、如果某个字符(或数值) x 与一个数值 m 进行异或运算得到有 y ,则再用 y 与 m 进行异或运算就可以还原为 x ,因此这个原理可以实现加密和解密功能。

三、代码详解

public class Basics26 
    public static void main(String[] args) 
        Scanner scan = new Scanner(System.in);
        System.out.println("请输入一个英文字符串或解密字符串");
        String password = scan.nextLine();// 获取用户输入
        char[] array = password.toCharArray();// 获取字符数组
        for (int i = 0; i < array.length; i++) // 遍历字符数组
            array[i] = (char) (array[i] ^ 20000);// 对每个数组元素进行异或运算
        
        System.out.println("加密或解密结果如下:");
        System.out.println(new String(array));// 输出密钥
    

四、推荐专栏

《JAVA从零到壹》

《JAVA从零到壹》第二讲:数据类型及运算符

五、示例源码下载

关注下面的公众号,回复筑基+题目号

筑基26

以上是关于第26题自己也能实现加密(位运算)的主要内容,如果未能解决你的问题,请参考以下文章

利用位运算简单实现加密运算

[位运算]签到题

20181019T1加密逆元+位运算

第43题组合位运算训练 (更新中)

乱序版 ● 剑指offer每日算法题打卡题解——位运算 (题号15,16,65)

算法题每日一练---第52天:位运算求解子集