Подскажите, пожалуйста, что пропустили мои глаза, что задача не может пройти валидацию?
Пишет, что "программа слишком долго работала и была закрыта"...
Спасибо)
package com.javarush.task.task19.task1916;
import java.io.BufferedReader;
import java.io.FileReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.ArrayList;
import java.util.List;
/*
Отслеживаем изменения
*/
public class Solution {
public static List<LineItem> lines = new ArrayList<LineItem>();
public static void main(String[] args) throws IOException {
BufferedReader readName = new BufferedReader(new InputStreamReader(System.in));
String namef1 = readName.readLine();
String namef2 = readName.readLine();
readName.close();
BufferedReader readf1 = new BufferedReader(new FileReader(namef1));
BufferedReader readf2 = new BufferedReader(new FileReader(namef2));
ArrayList<String> file1 = new ArrayList<>();
ArrayList<String> file2 = new ArrayList<>();
while (readf1.ready()) {
file1.add(readf1.readLine());
}
while(readf2.ready()) {
file2.add(readf2.readLine());
}
readf1.close();
readf2.close();
int f1Size = file1.size();
int f2Size = file2.size();
int i = 0;
int i2 = 0;
while (true) {
if (i < f1Size && i2 < f2Size) {
if (file1.get(i).equals(file2.equals(i2))) {
lines.add(new LineItem(Type.SAME, file1.get(i)));
++i;
++i2;
}
else if ((!file1.get(i).equals(file2.get(i2))) && (!file1.get(i).equals(file2.get(i2 + 1)))) {
lines.add(new LineItem(Type.REMOVED, file1.get(i)));
++i;
}
else if ((!file1.get(i).equals(file2.get(i2))) && (file1.get(i).equals(file2.get(i2 + 1)))) {
lines.add(new LineItem(Type.ADDED, file2.get(i2)));
++i2;
}
}
else if (i == f1Size && i2 < f2Size) {
if (file1.get(i).equals(file2.get(i2))) {
lines.add(new LineItem(Type.SAME, file1.get(i)));
for (int a = i2 + 1; a < f2Size; a++) {
lines.add(new LineItem(Type.ADDED, file2.get(a)));
}
break;
}
else if (!file1.get(i).equals(file2.get(i2))) {
lines.add(new LineItem(Type.REMOVED, file1.get(i)));
for (int a = i2; a < f2Size; a++) {
lines.add(new LineItem(Type.ADDED, file2.get(a)));
}
break;
}
}
else if (i < f1Size && i2 == f2Size) {
if (file1.get(i).equals(file2.get(i2))) {
lines.add(new LineItem(Type.SAME, file1.get(i)));
for (int a = i + 1; a < f1Size; a++) {
lines.add(new LineItem(Type.REMOVED, file1.get(a)));
}
break;
}
else if (!file1.get(i).equals(file2.get(i2))) {
lines.add(new LineItem(Type.REMOVED, file1.get(i)));
lines.add(new LineItem(Type.ADDED, file2.get(i2)));
for (int a = i + 1; a < f1Size; a++) {
lines.add(new LineItem(Type.REMOVED, file1.get(a)));
}
break;
}
}
else if (i == f1Size && i2 == f2Size) {
if (file1.get(i).equals(file2.get(i2))) {
lines.add(new LineItem(Type.SAME, file1.get(i)));
break;
}
else if (!file1.get(i).equals(file2.get(i2))) {
lines.add(new LineItem(Type.REMOVED, file1.get(i)));
lines.add(new LineItem(Type.ADDED, file2.get(i2)));
break;
}
}
}
}
public static enum Type {
ADDED, //добавлена новая строка
REMOVED, //удалена строка
SAME //без изменений
}
public static class LineItem {
public Type type;
public String line;
public LineItem(Type type, String line) {
this.type = type;
this.line = line;
}
}
}