[英]Java Generating Strings Recursively - All 1s then 1 and 0
大家好,我试图通过制作一个递归生成ArrayList
String
的程序来降低递归的概念。 我的基本算法是:
public static ArrayList<String> generateListOfAll1sStrings(int maxBits)
终端条件:如果maxBits为1,则返回最简单的情况:仅包含“ 1”的列表
否则:递归地调用generateListOfAll1sStrings()
以获取下一个最小的位长,保存返回的列表,以找到该列表中最长的字符串,并创建一个附加了“ 1”的新字符串(使下一个最长的字符串)返回一个新列表,其中包含较短列表的所有元素以及刚刚添加的新字符串。
到目前为止,我的代码是:
package bincomb.model;
import java.util.ArrayList;
public class BinaryCombinationGenerator {
public static ArrayList<String> generateListOfAll1sStrings(int maxBits) {
String string = null;
ArrayList<String> listofJust1 = new ArrayList<String>();
ArrayList<String> otherArray = new ArrayList<String>();
int i = 1;
if (maxBits == 1) {
listofJust1.add("1");
return listofJust1;
}
if (maxBits > 1) {
for (String string2 : listofJust1) {
String comp = "";
if (!(comp.equals(string2))) {
comp = string2;
}
string = comp;
}
listofJust1.add(i, (string + "1"));
i++;
listofJust1 = BinaryCombinationGenerator.generateListOfAll1sStrings((maxBits-1));
System.out.println(listofJust1);
return listofJust1;
}
return listofJust1;
}
public static void main(String[] args) {
generateListOfAll1sStrings(10);
}
}
但是,目前,我正在返回IndexOutOfBoundsException
。 我认为我的for循环引起了问题,但是我不确定如何解决它。
您在此行listofJust1.add(i, (string + "1"));
收到java.lang.IndexOutOfBoundsException
listofJust1.add(i, (string + "1"));
。
这是因为方法list.add(index,objects)尝试将对象添加到索引“ 1”,但是您的数组有0个元素。
要么将其更改为listofJust1.add(i-1, (string + "1"));
或者只是listofJust1.add((string + "1"));
@编辑:在这里:
listofJust1.add(i, (string + "1"));
您想为当前(N)级递归添加字符串,但在下面用以下命令替换此数组:
listofJust1 = BinaryCombinationGenerator.generateListOfAll1sStrings((maxBits-1));
基本上说“获取(maxBits-1)的结果并用listofJust1替换”,因此您将丢失之前添加的内容。
相反,您应该首先获取级别N-1的列表,然后添加当前级别的字符串:
listofJust1 = BinaryCombinationGenerator.generateListOfAll1sStrings((maxBits-1));
listofJust1.add(stringForThisLevel);
另外,您还需要重新思考如何在N级计算“字符串”,这似乎不正确。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.