Vigenère密码(洛谷P1079题题解,Java语言描述)
生活随笔
收集整理的這篇文章主要介紹了
Vigenère密码(洛谷P1079题题解,Java语言描述)
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
題目要求
P1079題目鏈接
分析
這題不太好講,做完有段時間了。
不過推出一堆式子挺麻煩的。
大家感興趣自己看一下。
推薦兩種比較極端的做法:
- ASCII碼超簡潔解法
- 慘絕人寰的打表做法
AC代碼(Java語言描述)
import java.util.Scanner;public class Main {public static void main(String[] args) {Scanner scanner = new Scanner(System.in);char[] chars1 = scanner.nextLine().trim().toCharArray();char[] chars2 = scanner.nextLine().trim().toCharArray();scanner.close();for (int i = 0; i < chars2.length; i++) {int temp = chars2[i] - chars1[i%chars1.length] + 26;boolean isUpper = Character.isUpperCase(chars1[i%chars1.length]);if (Character.isUpperCase(chars2[i])) {if (isUpper) {chars2[i] = (char)((temp % 26) + 'A');} else {chars2[i] = (char)(((temp - 'A' + 'a') % 26) + 'A');}} else {if (isUpper) {chars2[i] = (char)(((temp - 'a' + 'A') % 26) + 'a');} else {chars2[i] = (char)((temp % 26) + 'a');}}}System.out.println(new String(chars2));} }總結(jié)
以上是生活随笔為你收集整理的Vigenère密码(洛谷P1079题题解,Java语言描述)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 【JavaScript】百度地图API快
- 下一篇: 【软件工程】软件工程过程概述