Почему валидатор не принимает? что там за заморочки со служебным символом \uFEFF. Я в дебаге увидел что там он есть. Сделал так : если первый элемент в массиве, то удаляю этот символ для поиска пары, а потом добавляю в pair для корректного вывода, чтобы было "рот тор" а не "тор рот"
package com.javarush.task.task22.task2207;
import com.sun.org.apache.regexp.internal.RE;
import java.io.BufferedReader;
import java.io.FileReader;
import java.util.LinkedList;
import java.util.List;
import java.util.Scanner;
/*
Обращенные слова
*/
public class Solution {
public static List<Pair> result = new LinkedList<>();
public static void main(String[] args) throws Exception{
Scanner scanner = new Scanner(System.in);
String fileName = scanner.nextLine();
BufferedReader reader = new BufferedReader(new FileReader(fileName));
StringBuilder stringBuilder = new StringBuilder();
while (reader.ready()){
stringBuilder.append(reader.readLine());
stringBuilder.append(" ");
}
String[] words = stringBuilder.toString().split(" ");
for(int i = 0 ; i< words.length; i++){
StringBuilder str = new StringBuilder(words[i]);
if(i == 0 ) str.delete(0,1);
String test = str.toString();
str.reverse();
String reversed= str.toString();
for(int j = i ; j< words.length; j++){
if(reversed.equals(words[j]) && !reversed.equals("")){
Pair pair = new Pair();
pair.first = test;
pair.second = words[j];
if(!result.contains(pair)){
result.add(pair);
break;
}
}
}
}
for(Pair s : result)
System.out.println(s);
}
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;
//return first+" "+second;
}
}
}