Добрый день. Не могу понять почему BufferedReader в 23ей строке не ставит "1" после конца первой строки, а ставит её в самом конце файла. Из за этого я не могу разделить буквы "о" в файле, они сливаются в одну строку "оо". Прикрепляю содержание файла и вывод в консоли. Помогите разобраться, решил задачу за час и уже часа 2 сижу не могу понять что не так, уже и с Scanner'ом пробовал через .nextLine(), так же история.
package com.javarush.task.task22.task2207;
import java.io.*;
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 {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
String s = br.readLine();
StringBuilder strb = new StringBuilder();
try(BufferedReader bs = new BufferedReader( new FileReader(s))){
while(bs.ready()){
strb.append(bs.readLine());
strb.append("1");
}
StringBuilder Pop = new StringBuilder();
String ToString = strb.toString();
String[] massiv = ToString.split(" ");
for(String R:massiv){
System.out.print(R+ " ");
}
for(int c = 0; c<massiv.length;c++){
String gg = massiv[c];
for(int b = 0; b<massiv.length&&b!=c; b++){
if(gg.equals(new StringBuilder(massiv[b]).reverse().toString())){
// Pop.append(gg);
// Pop.append(" ");
// Pop.append(massiv[b]);
// Pop.append(" ");
Pair TT;
TT = new Pair();
TT.first = gg;
TT.second = massiv[b];
result.add(TT);
massiv[c]= "777777777777877887778778887";
massiv[b]= "7777777777778778877723187";
break;
}
}
}
// for(Pair y: result){
//// System.out.println(y.first +" "+ y.second);
// }
// System.out.println();
}
}
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;
}
}
}