На что еще обратить внимание? По условию выводится правильно.
package com.javarush.task.task22.task2207;
import java.io.*;
import java.util.*;
/*
Обращенные слова
*/
public class Solution {
public static List<Pair> result = new LinkedList<>();
public static void main(String[] args) throws IOException {
//------------------------------------------------ Читаю файл
BufferedReader rd = new BufferedReader(new InputStreamReader(System.in));
BufferedReader reader = new BufferedReader(new FileReader(rd.readLine()));
StringBuilder sb = new StringBuilder();
while(reader.ready()){
sb.append(reader.readLine() + " ");
}
//------------------------------------------------ Добавляю слова в ArrayList. Создал для того что бы можно было удалять обработанные строки.
ArrayList<String> list = new ArrayList<>();
Collections.addAll(list, sb.toString().substring(1,sb.length()).trim().split(" "));
//------------------------------------------------ Чищу Билдер для дальнейшей обработки во время перебора строк в цикле
sb.delete(0,sb.length());
//------------------------------------------------ Создаю Сет Коллекция , что бы избавится от одинаковых обьектов
Set<Pair> set = new LinkedHashSet<>();
//------------------------------------------------Создаю цикл перебора : элемент i будет проходить по каждому элементу в строке.
//------------------------------------------------ Если длина строк одинаковая то , с помощью Билдера перевертываем i1 и сравниваем на еквивалентность
//------------------------------------------------Если они эквивалентны, то : добавляем пару в Сет коолекцию, удаляем элемент i1 - что бы не было повтора.
for (int i = 0; i < list.size(); i++) {
for (int i1 = i; i1 < list.size(); i1++) {
if(list.get(i).length() == list.get(i1).length()){
sb.append(list.get(i1));
if(list.get(i).equals(sb.reverse().toString())){
set.add(new Pair(list.get(i),list.get(i1)));
list.remove(i1);
}
//-------------------------------------------------Обнуляю билдер на следующий круг цикла
sb.delete(0,sb.length());
}
}
}
//-------------------------------------------------Добавляю сет коллекцию в result. Повторов нет.
result.addAll(set);
for (Pair pair : result) {
System.out.println(pair);
}
}
public static class Pair {
String first;
String second;
public Pair(String first, String second) {
this.first = first;
this.second = second;
}
public Pair() {
}
@Override
public boolean equals(Object o) {
if (this == o) return true;
if (o == null || getClass() != o.getClass()) return false;
Pair pair = (Pair) o;
return Objects.equals(first, pair.first) &&
Objects.equals(second, pair.second);
}
@Override
public int hashCode() {
return Objects.hash(first, second);
}
@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;
}
}
}