Код не проходит валидатор, не понимаю в чем дело
package com.javarush.task.task22.task2207;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.nio.charset.StandardCharsets;
import java.nio.file.Files;
import java.nio.file.Paths;
import java.util.*;
/* Обращенные слова
В методе main с консоли считать имя файла, который содержит слова, разделенные пробелами.
Найти в тексте все пары слов, которые являются обращением друг друга. Добавить их в result.
Использовать StringBuilder.
Кодировка файла - UTF-8.
*/
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 fileName = reader.readLine();
reader.close();
BufferedReader fileReader = Files.newBufferedReader(Paths.get(fileName), StandardCharsets.UTF_8);
Queue<String> fileContentList = new LinkedList<>();
List<Pair> result = new LinkedList<>();
while (fileReader.ready()) {
String[] s = fileReader.readLine().split(" ");
for (int i = 0; i < s.length; i++) {
fileContentList.add(s[i]);
}
}
while (fileContentList.size()>=1) {
String s = fileContentList.poll().toString();
Iterator<String> iter = fileContentList.iterator();
while(iter.hasNext()){
StringBuilder a = new StringBuilder(iter.next());
if (s.equals(a.reverse().toString())) {
Pair pair = new Pair();
pair.setFirst(s);
pair.setSecond(a.reverse().toString());
result.add(pair);
fileContentList.remove(a.toString());
break;
}
}
}
for (Pair p : result
) {
System.out.println(p);
}
}
public static class Pair {
String first;
String second;
public Pair() {
}
public String getFirst() {
return first;
}
public void setFirst(String first) {
this.first = first;
}
public String getSecond() {
return second;
}
public void setSecond(String second) {
this.second = 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;
}
}
}