gpt4 book ai didi

java - 尝试在 Java 中实现凯撒密码

转载 作者:塔克拉玛干 更新时间:2023-11-03 05:43:31 25 4
gpt4 key购买 nike

我正在尝试在 Java 中实现凯撒密码加密,但是如果必须进行轮换,我会得到错误的输出,例如 key=2 并且文本是“zz”,输出应该是“bb”。我不知道下面的代码哪里错了。

import java.io.*;
import java.util.*;
import java.text.*;
import java.math.*;
import java.util.regex.*;

public class Solution {
public static void main(String[] args) {
Scanner in = new Scanner(System.in);
int n = in.nextInt();// length of the string
String s = in.next();// The string to be encrypted using caesar cipher
int k = in.nextInt();// The key k
int key;
for(int i =0;i<n;i++){
int ascii = (int)s.charAt(i);
if(s.charAt(i)=='-'){
System.out.print('-');
continue;
}
if(ascii >= 65 && ascii <=90){
if(k+ascii > 90){
k=k%26;
if(k==0){
k+=1;
}

ascii=64+k;
}
else{
ascii=ascii+k;
}
}
if(ascii >= 97 && ascii <=122){
if(k+ascii > 122){
k=k%26;
if(k==0){
k+=1;
}

ascii=96+k;
}
else{
ascii=ascii+k;
}
}
char c=(char)ascii;
System.out.print(c);
}
}
}

最佳答案

您的模计算错误。应该是:

k = k % 26; // not 26%k as you currently have

或者,更优雅地:

k %= 26;

关于java - 尝试在 Java 中实现凯撒密码,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37354201/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com