このコードを実行すると、次の行で範囲外の配列の例外が発生します。
int sum = array[k]+array[l]; //sum of l and k
...簡単な修正のはずですが、array.length を使用してループをバインドしているため、何が原因なのかわかりません。誰でも助けることができますか?
PS記録のために、このコードは、int配列を検索して、ターゲットintに等しいintのペアまたは単一のintを検索することになっています。println のみを使用して動作しますが、ターゲットに加算される数値をベクトルに入れようとしています。
public Vector<Vector<Integer>> subsetSum(int[] array, int target) {
//creates vectors, adds inner vector to another vector
outer = new Vector<Vector<Integer>>();
inner = new Vector<Integer>();
outer.add(inner);
for (int k = 0; k <= array.length; k++) {
for (int l = 0; l <= array.length; l++) {
int sum = array[k]+array[l]; //sum of l and k
int i = 0;
if (sum == target) {
inner.add(i, array[l]);
inner.add(i, array[k]);
i++;
//prints combination
System.out.println(array[l]+"+"+array[k]+"="+target);
}
if (k == target) {
inner.add(i, array[k]);
i++;
//prints if int equals target
System.out.println(k+"="+target);
}
if (l == target) {
inner.add(i, array[l]);
i++;
//prints if int equals target
System.out.println(l+"="+target);
}
}
}
//return combinations that add up to target in vector form
System.out.println(outer);
return outer;
}