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

标签 java

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

    }

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

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

对于差异 = 0 Legocats -> 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/

相关文章:

java - 分配给单个对象的字符串数组实例

java - Intellij、Maven 和 Eclipse 之间的编译差异

java - 在 java @configuration 类中初始化 init 方法属性的更好方法

java - 如何在java中制作倒数倒数计时器(秒表Java)

java - 从 Windows .NET 到 Android Java 的 Unicode 字符串

java - IDEA 启动本地 glassfish 服务器失败

java - Struts2性能

Java:在 "if"语句下不会打开警报窗口

java - 如何使Python脚本成为可执行程序

java - 相同 instanceof 但不同类的方法不可见性