package preda2.package_Preda_Reinas;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Iterator;
public class Vuelta_atras_reinas {
ArrayList<Integer[]> vector_solucion = new ArrayList<>();
public void reinas(Integer s[],Integer n,Integer k) {
s[k] = 0;
while (s[k]<= n-1)
{
s[k]++;
if(computable(s,k))
{
if(k==(n-1))
{
vector_solucion.add(s);
System.out.println("solución encontrada: "+Arrays.toString(s));
for(int i=0;i<vector_solucion.size();i++)
{
System.out.println("Size: "+vector_solucion.size()+" ["+i+"]"+Arrays.toString((Integer[]) vector_solucion.get(i)));
}
}
else reinas(s,n,k+1);
}
}
}
public boolean computable(Integer s[],Integer k)
{
for(Integer i=0;i<=k-1;i++)
{
// System.out.println("s[i] es "+s[i]+" s[k] es "+s[k]+" Math.abs(s[i]-s[k])es "+Math.abs(s[i]-s[k])+" Math.abs(i-k) es "+Math.abs(i-k));
if(s[i] == s[k] || (Math.abs(s[i]-s[k])==Math.abs(i-k)))
return false;
}
return true;
}
}
我用其他类的方法main调用函数reinas:
Vuelta_atras_reinas Vuelta_atras_reinas_Bi = new Vuelta_atras_reinas();
Integer s[]= new Integer[4];
Vuelta_atras_reinas_Bi.reinas(s,4,0);
结果是:
solución encontrada: [2, 4, 1, 3]
Size: 1 [0][2, 4, 1, 3]
solución encontrada: [3, 1, 4, 2]
Size: 2 [0][3, 1, 4, 2] <--- It must be [2,4,1,3]
Size: 2 [1][3, 1, 4, 2]
答案 0 :(得分:2)
您不断在列表中添加相同的唯一数组。因此,您最终会对列表中的相同数组进行N次引用。
如果要记住所有中间值,则需要在将数组添加到列表之前复制该数组。