Перепробывал кучу рабочих своих вариантов и чужих. Не пропускает последний пункт. Киньте что - ли свой, надоело упрашивать валидатор
package com.javarush.task.task22.task2207;
import java.io.*;
import java.nio.charset.StandardCharsets;
import java.nio.file.Files;
import java.nio.file.Paths;
import java.util.ArrayList;
import java.util.HashSet;
import java.util.LinkedList;
import java.util.List;
/*
Обращенные слова
*/
public class Solution {
public static List<Pair> result = new LinkedList<>();
public static List<Integer> processedWords = new ArrayList<>(); //обработанные словва
public static void main(String[] args) throws IOException {
BufferedReader reader = new BufferedReader(new InputStreamReader(System.in));
String fileName = reader.readLine();
reader.close();
List<String> filesStrings = Files.readAllLines(Paths.get(fileName));//, StandardCharsets.UTF_8
StringBuilder stringBuild = new StringBuilder();
for (String s: filesStrings ) {
stringBuild.append(s);
}
String[] srtingArray = stringBuild.toString().trim().split("\\s+");
for (int i = 0; i < srtingArray.length; i++) {
for (int j = i + 1; j < srtingArray.length; j++) {
String world_J = srtingArray[j];
String worldReverse = new StringBuilder(world_J).reverse().toString();
if(srtingArray[i].equals(worldReverse) )// нашли слово реверсное текущему
{
Pair pair = new Pair() ;
pair.first = srtingArray[i];
pair.second = srtingArray[j];
Pair tempPair = new Pair();
tempPair.first = pair.second;
tempPair.second = pair.first;
if (!result.contains(pair) && !result.contains(tempPair)) {
result.add(pair);
break;
}
}
}
}
for (Pair pair: result) {
System.out.println(pair.toString());
}
}
public static class Pair {
String first;
String second;
public Pair() {
}
public Pair(String first, String second) {
this.first = first;
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;
}
}
}