gpt4 book ai didi

java - 用其他字符替换字符

转载 作者:行者123 更新时间:2023-12-01 11:08:23 25 4
gpt4 key购买 nike

我想要破译某个文本。当我遇到字符串中的一个字母时,我想用字母表中的下一个字母替换它。然后在下一轮中我想用下一个字母替换。

a -> b

k -> l

然后在第二轮它应该尝试

a -> c

k -> 米

字符的问题在于它包含各种奇怪的字符,当你遇到 z 并尝试替换它时,它会被一个奇怪的符号替换。

谁能帮我从A到Z制作某种循环列表?在下面的代码片段中,我创建了一个包含 a 到 z 的列表。在循环中选择一个字符,搜索并“调整”它的索引,并且应该检索新字符。但这不起作用。 (列表不循环的原因之一)

public static void decipher(){
String cyphertext = "aVaqrprzoreoeratraWhyvhfraJnygreUbyynaqreqrgjrroebrefinaRqvguZnetbganneNzfgreqnzNaarjvytenntzrrxbzraznnezbrgabtrrarragvwqwrovwbznoyvwiraBznmnyurgzbrvyvwxuroorabzNaarabtrracnnejrxraqnnegrubhqrafpuevwsgRqvguSenaxvarraoevrsnnaTregehqAnhznaauhaiebrtrerohhezrvfwrvaSenaxshegnzZnva";
char[] plaintext = new char[cyphertext.length()];

List<Character> a2z = new ArrayList<Character>(26);
for (char c = 'A'; c <= 'Z'; c++){
a2z.add(Character.valueOf(c));
}

for(int i = 1; i < 26; i++){
for(int j = 0; j < cyphertext.length(); j++){
char currentChar = cyphertext.charAt(j);
int newCharIndex = a2z.indexOf(currentChar)+i;
plaintext[j] = a2z.get(newCharIndex);
}
}
}

最佳答案

您不需要循环列表来处理边缘情况。此外,您应该记住,字符 A-Z 的 ascii 值介于 65-90 之间,a-z 介于 97-122 之间。您可以创建两个循环列表,但不需要它们,因为边缘情况很容易处理:

public static void main(String[] args) {
String cyphertext = "aVaqrprzoreoeratraWhyvhfraJnygreUbyynaqreqrgjrroebrefinaRqvguZnetbganneNzfgreqnzNaarjvytenntzrrxbzraznnezbrgabtrrarragvwqwrovwbznoyvwiraBznmnyurgzbrvyvwxuroorabzNaarabtrracnnejrxraqnnegrubhqrafpuevwsgRqvguSenaxvarraoevrsnnaTregehqAnhznaauhaiebrtrerohhezrvfwrvaSenaxshegnzZnva";
char[] plaintext = new char[cyphertext.length()];

// first shift
shiftLetters(cyphertext, plaintext, 1);
// update cyphertext with the intermediate result
cyphertext = new String(plaintext);
// second shift
shiftLetters(cyphertext, plaintext, 2);
// print result
System.out.println(new String(plaintext));

}

private static void shiftLetters(String cyphertext, char[] plaintext, int shifts) {
for (int i=0; i<cyphertext.length(); i++){
int tmp = cyphertext.charAt(i) + shifts;
tmp = handleEdgeCases(tmp);
plaintext[i] = (char)(tmp);
}
}

// here we handle the "circular" cases
private static int handleEdgeCases(int tmp) {
if (tmp > 90 && tmp < 97) {
tmp = tmp - 90 + 65;
} else if (tmp > 122) {
tmp = tmp - 122 + 97;
}
return tmp;
}

关于java - 用其他字符替换字符,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32674154/

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