gpt4 book ai didi

java - 字符串插入时出现循环问题

转载 作者:行者123 更新时间:2023-12-01 21:59:39 25 4
gpt4 key购买 nike

所以我的最后一个问题出轨了,但我解决了问题(编译错误,很多)。现在我至少有一个逻辑错误,也许是两个。该程序的目的是通过反转字符串并根据“难度”值在每个“真实”字符之间添加一定数量的随机字母来“加密”字符串。 Here是整个代码。

以下是我认为给我带来问题的部分,更具体地说,我很确定它与我的 x = x + diff 语句有关,但我不知道我还能如何会移动“光标”。--Decryptor.java 的片段--

/**
decryptString decrypts the code based on using the difficulty as the increment.
@param code The encrypted string
@return decrypted The decrypted string
*/
public String decryptString(String code)
{
int length = code.length();
int x = 0; //to 1
encryptedStr = code;

String codeRev = new StringBuilder(code).reverse().toString();

StringBuilder decrypted = new StringBuilder();

for (int pos = 0; pos <= length; pos++)
{
if (x < length) //removed <=
{
decrypted.append(codeRev.charAt(x));
}
x = x + diff;
}
decryptedStr = decrypted.toString();
return(decrypted).toString();
}

--Encryptor.java 的片段--

/** 
encryptString encrypts the string, as well as stores the original for later use
@param str The string to be encrypted
@return encrypted The encrypted string
*/
public String encryptString(String str)
{
int length = str.length();
origStr = str;
int x = 0; //to 0
StringBuilder codeRev = new StringBuilder(str).reverse();

for (int pos = 0; pos <= length; pos++)
{
if (x < length + diff) //removed
{
codeRev.insert(x, randomLetter());
}
x = x + diff;
}
encryptedStr = codeRev.toString();
return(codeRev).toString();

}

如果有人可以帮助我修改循环以使其按预期运行,我将不胜感激。我一整天都断断续续地尝试这个东西。

这是它应该执行的操作的示例:

对于差异 = 0Legocats -> stacogeL -> Legocats

对于差异 = 1乐高猫 -> s_t_a_c_o_g_e_L -> 乐高猫“_”代表随机字母。

预先感谢您的帮助。

最佳答案

尚未验证您的代码,但应该不会太困难。

为了解密,假设我们有一个字符串

A_B_C_D  (difficulty = 1), 

您可以做的是将光标设置到末尾(并附加到结果):

A_B_C_D
^

对于每次迭代,向后移动 diff + 1 元素,例如在这种情况下向后移动 2

A_B_C_D
^

直到您通过索引 0。这是伪代码

String decrypt(String encryptedString) {
int i = encryptedString.length() - 1;
String result = "" ; // use a String builder in real life of course

for (int i = encryptedString.length() - 1 // last index
; i >= 0
; i -= (diff + 1) ) {
result += encryptedString[i];
}
return result;
}

就是这么简单。这避免了执行反向操作的额外步骤(从而节省了不必要的内存浪费),而不会损失可读性。

加密更加容易:

String encrypt (String input) {
String result;
for (int i = input.length() - 1
; i >= 0
; --i) {
result += input[i];
if (i > 0) {
append "diff" number of random character to result
}
}
return result;
}

关于java - 字符串插入时出现循环问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33794010/

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