Vigenère密码(洛谷P1079题题解,Java语言描述)

题目要求

P1079题目链接
在这里插入图片描述
在这里插入图片描述

分析

这题不太好讲,做完有段时间了。
不过推出一堆式子挺麻烦的。
大家感兴趣自己看一下。

推荐两种比较极端的做法:

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));
    }
}
发布了717 篇原创文章 · 获赞 1513 · 访问量 69万+

猜你喜欢

转载自blog.csdn.net/weixin_43896318/article/details/104852487
今日推荐