доброго дня! допоможіть розібратися. по завданню виводить все коректно.
буду вдячний))
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.ArrayList;
import java.util.LinkedList;
import java.util.List;
/*
Обращенные слова
*/
public class Solution {
public static List<Pair> result = new LinkedList<>();
public static List<String> list = new ArrayList<>();
public static void main(String[] args) throws IOException
{
BufferedReader reader = new BufferedReader(new InputStreamReader(System.in));
String fileName = reader.readLine();
reader.close();
BufferedReader fileReader = new BufferedReader(new FileReader(fileName));
String line;
while ((line = fileReader.readLine())!=null)
{
//String line = fileRead.readLine().replace("\uFEFF", "");
String s = line.replace("\uFEFF", "").trim();
for (String word:s.split(" +"))
{
list.add(word);
}
}
fileReader.close();
for (int i = 0; i < list.size();i++ ) {
for (int j = 0; j < list.size();j++) {
String word = list.get(i);
String reversWord = list.get(j);
StringBuilder sb = new StringBuilder(word);
String wordRev = sb.reverse().toString();
if (wordRev.equals(reversWord))
{
result.add(new Pair(list.get(i), list.get(j)));
// System.out.println(list.get(i) + " " + list.get(j));
for (int k = 0; k <list.size() ; k++) {
if(word.equals(list.get(k)))
{
list.remove(k);
break;
}}
for (int l = 0; l < list.size(); l++) {
if (reversWord.equals(list.get(l)))
{
list.remove(l);
break;
}
}
/* System.out.println();
for (String string : list) {
System.out.print(string + " ");
}
System.out.println();*/
/*рот | тор
торт | трот
о | о
тот | тот
тот | тот
азора | ароза
ашпала | алапша
тор | рот
рот | тор
рот | тор
о | о
тот | тот
рот тор
торт трот
о о
тот тот
азора ароза
алапша ашпала
рот тор
тот тот
рот тор
о о
тот тот
тот тот
*/
}
else{}
}
}
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;
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;
}
}
}