Объясните пожалуйста почему валидатор не принимает мое первое решение? Сначала решил сделать задачу через паттерны и работу со StringBuilder'ом и вроде как с различными входными данными все работает нормально. Но валидатору такой код не нравится.
package com.javarush.task.task22.task2207;

import java.io.*;
import java.util.LinkedList;
import java.util.List;
import java.util.regex.Matcher;
import java.util.regex.Pattern;

/*
Обращенные слова
*/
public class Solution {
    public static List<Pair> result = new LinkedList<>();

    public static void main(String[] args) throws IOException {
        try (BufferedReader reader = new BufferedReader(new InputStreamReader(new FileInputStream(new BufferedReader(new InputStreamReader(System.in)).readLine()), "UTF-8"))) {
            StringBuilder mainString = new StringBuilder();
            while (reader.ready()) {
                mainString.append(reader.readLine()).append(" ");
            }
            Pattern pattern = Pattern.compile("\\b([А-Яа-яA-Za-z]+)\\b");
            Matcher matcher = pattern.matcher(mainString.toString());

            while (matcher.find()) {
                String tmp = matcher.group(1);
                mainString.delete(matcher.start(1), matcher.end(1) + 1);
                matcher.reset(mainString.toString());

                while (matcher.find()) {
                    String reverseTmp = new StringBuilder(tmp).reverse().toString();
                    if(!mainString.toString().contains(reverseTmp)){
                        break;
                    }
                    if (reverseTmp.equals(matcher.group(1))) {
                        Pair p = new Pair();
                        p.first = tmp;
                        p.second = matcher.group(1);
                        result.add(p);
                        mainString.delete(matcher.start(1), matcher.end(1) + 1);
                        matcher.reset(mainString.toString());
                        break;
                    }
                }
            }
        }

        for (Pair x : result) {
            System.out.println(x.first + " " + x.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 != null ? second :
                            second == null && first != null ? first :
                                    first.compareTo(second) < 0 ? first + " " + second : second + " " + first;

        }
    }

}
После нескольких попыток угодить валидатору принял решение полностью переписать код, и валидатор его принял с первого раза. Почему? Что его не устраивало в предыдущем варианте?
package com.javarush.task.task22.task2207;


import java.io.BufferedReader;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.*;

public class Solution {
    public static List<Pair> result = new LinkedList<>();

    public static void main(String[] args) throws IOException {
        try (BufferedReader reader = new BufferedReader(new InputStreamReader(new FileInputStream(new BufferedReader(new InputStreamReader(System.in)).readLine()), "UTF-8"))) {
            StringBuilder str = new StringBuilder();
            ArrayList<String> list = new ArrayList<>();
            while (reader.ready()) {
                String[] arr = reader.readLine().split(" ");
                list.addAll(Arrays.asList(arr));
            }
            for (int i = 0; i < list.size(); i++) {
                String s1 = list.get(i);
                list.remove(i);
                for (int j = 0; j < list.size(); j++) {
                    str.append(list.get(j)).reverse();
                    if (s1.equals(str.toString())) {
                        Pair p = new Pair();
                        p.first = s1;
                        p.second = list.get(j);
                        result.add(p);
                        list.remove(j);
                        str.delete(0, str.length());
                        i--;
                        break;
                    }else {
                        str.delete(0, str.length());
                    }
                }
            }
        }
        //System.out.println(result);
        for (Pair x : result) {
            System.out.println(x.first + " " + x.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 != null ? second :
                            second == null && first != null ? first :
                                    first.compareTo(second) < 0 ? first + " " + second : second + " " + first;
        }
    }
}