最难的问题:把发送来的消息破译出来、并提供给你的将军

题目:最难的问题      最难的问题

        NowCoder生活在充满危险和阴谋的年代。为了生存,他首次发明了密码,用于军队的消息传递。假设你是军团中的一名军官,需要把发送来的消息破译出来、并提
供给你的将军。
        消息加密的办法是:对消息原文中的每个字母,分别用该字母之后的第5个字母替换(例如:消息原文中的每个字母A 都分别替换成字母F),其他字符不 变,并且消息原文的所有字母都是大写的。密码中的字母与原文中的字母对应关系如下。
密码字母:A B C D E F G H I J K L M N O P Q R S T U V W X Y Z
原文字母:V W X Y Z A B C D E F G H I J K L M N O P Q R S T U

输入描述:
        输入包括多组数据,每组数据一行,为收到的密文。
        密文仅有空格和大写字母组成。

输出描述:
        对应每一组数据,输出解密后的明文。示例1
输入

HELLO WORLD

SNHJ
输出
CZGGJ RJMGY

NICE

思路:

        找规律。

密码字母:A B C D E F G H I J K L M N O P Q R S T U V W X Y Z
原文字母:V W X Y Z A B C D E F G H I J K L M N O P Q R S T U

  不能单纯的用 +5 找到后面字母进行替换,要分情况。
当密码字母:F ~ Z 时候: 原文 = 密码 - 5  (>’E’)
当密码字母:A ~ E时候:  原文 = 密码 + 21

代码:

import java.util.*;

/**
 * Created with IntelliJ IDEA.
 * Description: 最难的问题
 * 当密码字母:F ~ Z 时候: 原文 = 密码 - 5
 * 当密码字母:A ~ E时候:  原文 = 密码 + 21
 * User: WangWZ
 * Date: 2023-04-10
 * Time: 15:46
 */
public class Main {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        while(scanner.hasNext()) {
            String str = scanner.nextLine();
            StringBuilder sb = new StringBuilder();
            for(int i = 0; i < str.length(); i++) {
                char a = str.charAt(i);
                if (a == ' ') {
                    sb.append(' ');
                } else {
                    sb.append((char)(a >'E'? a - 5: a + 21));
                }
            }
            System.out.println(sb);
        }
    }
}

         

你可能感兴趣的:(题目练习,数据结构)