Обращенные слова В методе main с консоли считать имя файла, который содержит слова, разделенные пробелами. Найти в тексте все пары слов, которые являются обращением друг друга. Добавить их в result. Использовать StringBuilder. Пример содержимого файла рот тор торт о о тот тот тот Вывод: рот тор о о тот тот Требования: 1. Метод main должен считывать имя файла с клавиатуры. 2. В методе main должен быть использован StringBuilder 3. Список result должен быть заполнен корректными парами согласно условию задачи. 4. В классе Solution должен содержаться вложенный класс Pair. 5. В классе Pair должен быть объявлен конструктор без параметров (или конструктор по умолчанию).
public class Solution {
    public static List<Pair> result = new LinkedList<>();

    public static void main(String[] args) throws IOException {
        BufferedReader reader = new BufferedReader(new InputStreamReader(System.in));
        String name = reader.readLine();
        BufferedReader fileReader = new BufferedReader(new FileReader(name));
        ArrayList<String> list = new ArrayList<>();

        while (fileReader.ready()){
            String[] str = fileReader.readLine().split("\\s");
            for (String s:str) {
                list.add(s);
            }
        }
        reader.close();
        fileReader.close();
        for (int i =1; i< list.size()-1;i++) {
            StringBuilder sb = new StringBuilder(list.get(i));
            String reversWord = sb.reverse().toString().trim();

            for(int j = 0;j<list.size();j++){
                if(reversWord.equals(list.get(j))){
                    Pair pair = new Pair();
                    pair.first=list.get(i);
                    pair.second=list.get(j);
                    result.add(pair);
                    list.remove(i);
                    list.remove(j);
                    i--;
                    j--;
                    break;
                }
            }
        }
    }

  public static   class Pair {
        String first;
        String second;

      public Pair() {
      }

      @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;

        }
    }

}