我正在尝试递归运行我的方法。在方法的每次迭代中,我都会创建新的ArrayList
并填充一些值并检查if
运算符中的一些条件。如果为真,将再次运行此方法。如果它是假的,我想退出当前的方法迭代,并在之前的方法迭代中使用ArrayList
. 在实践中,当我的条件为假并进入我的方法的先前迭代时,我使用相同的ArrayList
. 这很糟糕。
我如何ArrayList
为方法的每次迭代创建每个实例,以及在上一个方法中使用该迭代的实例时返回时如何工作ArrayList
?
我的代码:
private List<List<String>> letsTry(List<List<ProbableValue>>
probableValues, List<List<String>> data) {
List<List<String>> copyOfData = new ArrayList<List<String>>(data);
List<List<ProbableValue>> copyOfProbableValues =
new ArrayList<List<ProbableValue>>(probableValues);
ProbableValue minPV = getMinPV(copyOfProbableValues);
Set<String> pValues = new HashSet<String>(minPV.getProbableValues());
int i = minPV.getI();
int j = minPV.getJ();
for (String v : pValues) {
if (checker.canSetOnTable(copyOfProbableValues, minPV)) {
if (!SUtils.isItsNumber(copyOfData.get(i).get(j))) {
copyOfData.get(i).set(j, v);
copyOfProbableValues.get(i).get(j).getProbableValues().clear();
checker.removeProbableValue(copyOfProbableValues, v, i, j);
}
letsTry(new ArrayList<List<ProbableValue>>(copyOfProbableValues),
new ArrayList<List<String>>(copyOfData));
}
}
return copyOfData;
}