Добрый день.
От незнания того, как добавить пару в result таким образом, чтобы не получилось
рот тор
тор рот
Я добавил метод reversePlace(Pair pair), он в самом низу класса Pair.
Вывод верный, но последний пункт не проходит и даже наставник ничего не говорит.
Подскажите, пожалуйста, в чем проблема.
package com.javarush.task.task22.task2207;
import java.io.BufferedReader;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStreamReader;
import java.nio.charset.StandardCharsets;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.LinkedList;
import java.util.List;
/*
Обращенные слова
*/
public class Solution {
public static List<Pair> result = new LinkedList<>();
public static void main(String[] args) throws IOException {
InputStreamReader isr = new InputStreamReader(System.in);
BufferedReader fileNameReader = new BufferedReader(isr);
String fileName = fileNameReader.readLine();
fileNameReader.close();
ArrayList<String> list = new ArrayList<>();
InputStreamReader inputStreamReader = new InputStreamReader(new FileInputStream(fileName), StandardCharsets.UTF_8);
BufferedReader reader = new BufferedReader(inputStreamReader);
while (reader.ready()) {
String[] s = reader.readLine().replace("\uFEFF", "").split(" ");
list.addAll(Arrays.asList(s));
}
reader.close();
list.removeIf(s-> (s.equals(" ")));
for (int i = 0; i < list.size(); i++) {
StringBuilder sb = new StringBuilder(list.get(i));
if (list.contains(new String(sb.reverse()))) {
Pair pair = new Pair();
pair.first = sb.toString();
pair.second = new String(sb.reverse());
if (!result.contains(pair) && !result.contains(Pair.reversePlace(pair))) {
result.add(pair);
}
}
}
for (Pair pair : result) {
System.out.printf("%s %s%n", pair.first, pair.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;
}
public static Pair reversePlace(Pair pair) {
String s = pair.first;
pair.first = pair.second;
pair.second = s;
return pair;
}
}
}