Вывод совпадает с примером.
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 reader = new BufferedReader(new InputStreamReader(System.in));
File file = new File(reader.readLine());
Scanner scanner = new Scanner(file);
reader.close();
ArrayList<String> list = new ArrayList<>(); //лист для добавления слов из файла
list.add(scanner.next().replaceAll("\uFEFF", "")); //добавляем первое слово в лист без "\uFEFF"
while(scanner.hasNext()){
list.add(scanner.next()); // заполняем лист словами
}
scanner.close(); // закрываем поток
Pair pair;
String first;
String second;
for (int i = 0; i < list.size();) { //прогоняем циклом лист, сравниваем элементы, если не один и тот же элемент, то добавляем в пару и удаляем эту пару из листа
first = list.get(i);
second = new StringBuilder(first).reverse().toString();
for (int j = 0; j < list.size(); j++) {
if (list.contains(second) && i!=j) {
pair = new Pair();
pair.first = first;
pair.second = second;
result.add(pair);
break;
}
}
list.remove(first);
list.remove(second);
}
/*while(list.size() != 0) {
first = list.get(0);
second = new StringBuilder(first).reverse().toString();
if(list.contains(second)){
pair = new Pair();
pair.first = first;
pair.second = second;
result.add(pair);
}
list.remove(first);
list.remove(second);
System.out.println(list);
*/
for (Pair pair1 : result) {
System.out.println(pair1.first + " " + pair1.second);
}
/* при содержимом файла:
"рот тор торт о
о тот тот тот"
результат вывода:
"рот тор
о о
тот тот"
*/
}
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;
}
}
}