When I print out result for testing I get:
rat tar
a a
tot tot
package com.codegym.task.task22.task2207;
import java.io.BufferedReader;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.*;
/*
Inverted words
*/
public class Solution {
public static List<Pair> result = new LinkedList<>();
public static void main(String[] args) throws IOException {
// read filename from console
Scanner scanner = new Scanner(System.in);
String fileName = scanner.nextLine();
// String fileName = "C:\\Users\\Andrew Cate\\CodeGym\\CodeGymTasks\\3.JavaMultithreading\\src\\com\\codegym\\task\\task22\\task2207\\test.txt";
// read the file contents into a list
BufferedReader bufferedReader = new BufferedReader(new InputStreamReader(new FileInputStream(fileName)));
List<String> fileContents = new ArrayList<>();
while (bufferedReader.ready()) {
String line = bufferedReader.readLine();
String[] array = line.split(" ");
fileContents.addAll(Arrays.asList(array));
}
// process the list, adding valid pairs to result list
for (int i = 0; i < fileContents.size() - 1; i++) {
// create a pair with the next two items in list
Pair pair = new Pair();
pair.first = fileContents.get(i);
pair.second = fileContents.get(i + 1);
// create another pair with first being current item from list and second being reverse of first
Pair reversePair = new Pair();
StringBuilder stringBuilder = new StringBuilder(fileContents.get(i));
reversePair.first = stringBuilder.toString();
reversePair.second = stringBuilder.reverse().toString();
// compare pairs and add to list if equal and not already in the list
if (pair.equals(reversePair)) if (!result.contains(pair)) result.add(pair);
}
// print pairs for testing
// for (Pair p :
// result) {
// System.out.println(p.first + " " + p.second);
// }
scanner.close();
bufferedReader.close();
}
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;
}
}
}