Не пойму где ошибка. Вывод на экран как в условии
package com.javarush.task.task22.task2207;
import java.io.BufferedReader;
import java.io.FileReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.LinkedList;
import java.util.List;
/*
Обращенные слова
*/
public class Solution {
public static List<Pair> result = new LinkedList<>();
public static void main(String[] args) throws IOException {
// создаю ридеры
BufferedReader consoleReader = new BufferedReader(new InputStreamReader(System.in));
FileReader fileReader = new FileReader(consoleReader.readLine());
BufferedReader fileBufferedReader = new BufferedReader(fileReader);
consoleReader.close();
// создаю список для слов
List<String> strings = new ArrayList<>();
// заполняю список
while (fileBufferedReader.ready()) {
String[] strArr = fileBufferedReader.readLine().split(" ");
strings.addAll(Arrays.asList(strArr));
}
// в двойном цикле прохожу список
for (int i = 0; i < strings.size(); i++) {
for (int j = 0; j < strings.size(); j++) {
String first = strings.get(i);
// добаляю ограничение, чтобы не выйти за пределы списка
if (j+1 < strings.size()){
StringBuilder second = new StringBuilder(strings.get(j + 1)).reverse();
// если найдено совпадение, создаю pair и удалаю оба элемента
if (first.equals(second.toString())) {
Pair pair = new Pair();
pair.first = first;
pair.second = second.reverse().toString();
result.add(pair);
strings.remove(i);
strings.remove(j); // не удаляю j+1 так как список стал короче после удаления элемента i
}
}
}
}
fileBufferedReader.close();
for (Pair nextPair : result){
System.out.println(nextPair);
}
}
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 :
second == null ? first :
first.compareTo(second) < 0 ? first + " " + second : second + " " + first;
}
}
}