心法领悟023:灵活使用位运算。
灵活运用位运算可以实现很多高级、高效的算法。例如,一个数字的位移运算,每左移n位,就等于这个数乘以2的n次方,每右移n位,就等于这个数除以2的n次方,而且这个算法非常快。
import java.util.Scanner;
public class Example {
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.err.println(new String(array));// 输出密钥
scan.close();
}
}
请输入一个英文字符串或解密字符串
www.qq.com
加密或解密结果如下:
乗乗乗与乑乑与乃乏乍
请输入一个英文字符串或解密字符串
乗乗乗与乑乑与乃乏乍
加密或解密结果如下:
www.qq.com