Не могу понять в чем проблема. Читаю файл в стригбилденр, делю слова сплитом в массив, затем сравниваю с остальными перевернутыми словами из массива. Тут возникает проблема - если в массиве есть нужные слова, но одно из них в начале массива, то метод equals не считает их одинаковыми (хотя при пробежке дебагером переменные содержат одинаковые значения), если слова переставить местами, то все работает. В чем проблема?
package com.javarush.task.task22.task2207;

import java.io.BufferedReader;
import java.io.FileInputStream;
import java.io.FileReader;
import java.io.InputStreamReader;
import java.util.LinkedList;
import java.util.List;

/*
Обращенные слова
*/
public class Solution {
    public static List<Pair> result = new LinkedList<>();

    public static void main(String[] args) {
        //C:/Users/Hedgehog/Documents/test.txt
        try (BufferedReader reader = new BufferedReader(new InputStreamReader(System.in));
             BufferedReader fileReader = new BufferedReader(new InputStreamReader(new FileInputStream(reader.readLine()),"UTF-8"))
        )
        {
            StringBuilder buffer = new StringBuilder();
            while(fileReader.ready()){
                buffer.append(fileReader.readLine());
            }

            String[] words = buffer.toString().split("\\s");
            for (int i = 0 ; i < words.length - 1; i++){
                String firsWord = words[i];

                for (int j = i+1; j < words.length;j++){
                    String anotherWord = words[j];
                    String reverseWord = new StringBuilder(anotherWord).reverse().toString();

                    if (reverseWord.equals(firsWord)){
                        Pair pair = new Pair();
                        pair.first = firsWord;
                        pair.second = anotherWord;

                        if (!result.contains(pair)){
                            result.add(pair);
                        }
                    }

                }
            }

            for (Pair pair : result){
                System.out.println(pair);
            }

        }catch (Exception e){

        }


    }

    public static class Pair {
        String first;
        String second;

        @Override
        public boolean equals(Object o) {
            if (this == o) return true;
            if (o == null || getClass() != o.getClass()) return false;

            Pair pair = (Pair) o;

            if (first != null ? !first.equals(pair.first) : pair.first != null) return false;
            return second != null ? second.equals(pair.second) : pair.second == null;

        }

        @Override
        public int hashCode() {
            int result = first != null ? first.hashCode() : 0;
            result = 31 * result + (second != null ? second.hashCode() : 0);
            return result;
        }

        @Override
        public String toString() {
            return  first == null && second == null ? "" :
                    first == null && second != null ? second :
                    second == null && first != null ? first :
                    first.compareTo(second) < 0 ? first + " " + second : second + " " + first;

        }
    }

}