I am doing the 8 queens problem and trying to implement the method which will check if there is any collision between queens. When it comes to the logic of the problem, I think I understand it, but I am getting NullpointerException and I can't figure out why. Any help would be highly appreciated.
private static boolean isOK(int[][] matrix) {
boolean isInCollision = false;
Queen [] queens = new Queen[8];
for (int i = 0; i < matrix.length; i++) {
for (int j = 0; j < matrix.length; j++) {
if(matrix[i][j] == 1){
queens[i] = new Queen(i, j);
}
}
}
for (int i = 0; i < queens.length; i++) {
for (int j = i+1; j < queens.length; j++) {
if(queens[i].getX()==queens[j].getX() && Math.abs(queens[i].getX()-queens[j].getX())==Math.abs(queens[i].getY()-queens[j].getY())){
isInCollision = true;
}
}
}
return isInCollision;
}
I get error in this line of code:
if(queens[i].getX()==queens[j].getX() && Math.abs(queens[i].getX()-queens[j].getX())==Math.abs(queens[i].getY()-queens[j].getY()))