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()))
 
     
    