日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > java >内容正文

java

潜伏者与谍报密码(洛谷P1071题题解,Java语言描述)

發布時間:2025/3/15 java 18 豆豆
生活随笔 收集整理的這篇文章主要介紹了 潜伏者与谍报密码(洛谷P1071题题解,Java语言描述) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

題目要求

P1071題目鏈接


分析

這道題其實要構建唯一的雙射,開始沒讀明白,寫出了下面的代碼:

import java.util.HashMap; import java.util.Map; import java.util.Scanner;public class Main {public static void main(String[] args) {Map<Character, Character> map = new HashMap<>();Scanner scanner = new Scanner(System.in);char[] cipher = scanner.nextLine().trim().toCharArray();char[] origin = scanner.nextLine().trim().toCharArray();char[] chars = scanner.nextLine().trim().toCharArray();scanner.close();for (int i = 0; i < cipher.length; i++) {char c1 = cipher[i], c2 = origin[i];if (map.containsKey(c1)) {if (map.get(c1)!=c2) {System.out.println("Failed");return;}} else {map.put(c1, c2);}}if (map.size() < 26) {System.out.println("Failed");return;}char[] result = new char[chars.length];for (int i = 0; i < chars.length; i++) {result[i] = map.get(chars[i]);}System.out.println(new String(result));} }

此外,這個題要求的是我們從原文進行加密,輸出的是密文,一定要清楚不是輸出破解密文得到的文字。

AC代碼(Java語言描述)

import java.util.HashMap; import java.util.Map; import java.util.Scanner;public class Main {public static void main(String[] args) {Map<Character, Character> map1 = new HashMap<>();Map<Character, Character> map2 = new HashMap<>();Scanner scanner = new Scanner(System.in);char[] cipher = scanner.nextLine().trim().toCharArray();char[] origin = scanner.nextLine().trim().toCharArray();char[] chars = scanner.nextLine().trim().toCharArray();scanner.close();for (int i = 0; i < cipher.length; i++) {char c1 = cipher[i], c2 = origin[i];if (map1.containsKey(c1)) {if (map1.get(c1)!=c2) {System.out.println("Failed");return;}} else {map1.put(c1, c2);}if (map2.containsKey(c2)) {if (map2.get(c2)!=c1) {System.out.println("Failed");return;}} else {map2.put(c2, c1);}}if (map1.size() < 26 || map2.size() < 26) {System.out.println("Failed");return;}char[] result = new char[chars.length];for (int i = 0; i < chars.length; i++) {result[i] = map1.get(chars[i]);}System.out.println(new String(result));} }

總結

以上是生活随笔為你收集整理的潜伏者与谍报密码(洛谷P1071题题解,Java语言描述)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。