1)сохранил все слова в лист из файла
2)добавил в сет слова у которых есть полиндром с помощью стрима, тут же сет сам по себе сразу отсеял повторы. В итоге в сете остались слова и их полиндромы
3)очистил лист (чтобы новый не создавать просто) и добавлял в него только то Слово, у которых в этом листе нет копий и полиндромов этого Слова
4) здесь же проводил проверку на то, что если лист окажется пустой, то ничего не добвлять в лист result (это лист который проверяет валидатор)
Подскажите пожалуйста, что не учел?
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.*;
import java.util.stream.Collectors;
/*
Обращенные слова
*/
public class Solution {
public static List<Pair> result = new LinkedList<>();
public static void main(String[] args) {
String fileName = getFileName();
// String fileName = "/home/upc/qwe";
try (BufferedReader reader = new BufferedReader(new FileReader(fileName))) {
List<String> list = new ArrayList<>();
while (reader.ready()) {
String[] line = reader.readLine().split(" ");
Collections.addAll(list, line);
}
// System.out.println(list);
StringBuilder sb = new StringBuilder();
Set<String> set = list.stream().filter((stringFromList) -> {
sb.delete(0, sb.length());
if (list.contains(sb.append(stringFromList).reverse().toString())) {
return true;
} else {
return false;
}
}).collect(Collectors.toSet());
// System.out.println(set);
list.clear();
for (String word : set) {
sb.delete(0, sb.length());
String wordReverse = sb.append(word).reverse().toString();
if (!(list.contains(word)) && !(list.contains(wordReverse))) {
list.add(word);
if (!(list.isEmpty())) {
Pair pair = new Pair();
pair.first = word;
pair.second = wordReverse;
result.add(pair);
}
}
}
// System.out.println(list);
// System.out.println(result);
} catch (Exception e) {}
}
private static String getFileName() {
String fileName = "";
try (BufferedReader reader = new BufferedReader(new InputStreamReader(System.in))) {
fileName = reader.readLine();
} catch (IOException e) {}
return fileName;
}
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;
}
}
}