Валидатор ругается. Хотя все работает. Анализ выполняется.
Требование: Программа работала слишком долго и будет закрыта.
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 scanner = new BufferedReader(new InputStreamReader(System.in));
String fileName1 = scanner.readLine();
String fileName2 = scanner.readLine();
scanner.close();
FileReader reader1 = new FileReader(fileName1);
FileReader reader2 = new FileReader(fileName2);
StringBuffer buffer = new StringBuffer();
int readableSymbol = 0;
while ((readableSymbol =reader1.read())!=-1)
{
buffer.append((char)readableSymbol);
}
reader1.close();
String[] stringsFile1 = buffer.toString().split("\\n");
buffer.delete(0,buffer.length());
while ((readableSymbol =reader2.read())!=-1)
{
buffer.append((char)readableSymbol);
}
reader2.close();
String[] stringsFile2 = buffer.toString().split("\\n");
int specialIndex = 0;
int i = 0;
while (i <= stringsFile2.length)
{
if (i < stringsFile2.length) {
if ((i+specialIndex<stringsFile1.length) && (stringsFile2[i].equals(stringsFile1[i + specialIndex]))) {
LineItem item = new LineItem(Type.SAME, stringsFile2[i]);
lines.add(item);
} else if ((i+1+specialIndex < stringsFile1.length)&&(stringsFile2[i].equals(stringsFile1[i + 1 + specialIndex]))) {
LineItem item = new LineItem(Type.REMOVED, stringsFile1[i + specialIndex]);
lines.add(item);
specialIndex = specialIndex + 1;
--i;
} else {
if ((i + specialIndex<stringsFile1.length) && (stringsFile2[i + 1].equals(stringsFile1[i + specialIndex]))) {
LineItem item = new LineItem(Type.ADDED, stringsFile2[i]);
lines.add(item);
specialIndex = specialIndex - 1;
}
}
}
else {if (stringsFile1.length > stringsFile2.length +specialIndex) { LineItem item = new LineItem(Type.REMOVED, stringsFile1[i + specialIndex]); lines.add(item);}
if (stringsFile2.length +specialIndex > stringsFile1.length) { LineItem item = new LineItem(Type.ADDED, stringsFile2[stringsFile2.length -1]); lines.add(item);}
}
i++;
}
}
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;
}
}
}
/*
C:\Users\loparev_pv\Desktop\Text3.txt
C:\Users\loparev_pv\Desktop\Новый текстовый документ.txt
Отслеживаем изменения
Считать с консоли 2 имени файла - file1, file2.
Файлы содержат строки, file2 является обновленной версией file1, часть строк совпадают.
Нужно создать объединенную версию строк, записать их в список lines.
Операции ADDED и REMOVED не могут идти подряд, они всегда разделены SAME.
Пустые строки даны в примере для наглядности.
В оригинальном и редактируемом файлах пустых строк нет!
Пример 1:
оригинальный редактированный общий
file1: file2: результат:(lines)
строка1 строка1 SAME строка1
строка2 REMOVED строка2
строка3 строка3 SAME строка3
строка4 REMOVED строка4
строка5 строка5 SAME строка5
строка0 ADDED строка0
строка1 строка1 SAME строка1
строка2 REMOVED строка2
строка3 строка3 SAME строка3
строка4 ADDED строка4
строка5 строка5 SAME строка5
строка0 REMOVED строка0
Пример 2:
оригинальный редактированный общий
file1: file2: результат:(lines)
строка1 строка1 SAME строка1
строка0 ADDED строка0
Пустые строки в примере означают, что этой строки нет в определенном файле.
Требования:
1. Класс Solution должен содержать класс LineItem.
2. Класс Solution должен содержать enum Type.
3. Класс Solution должен содержать публичное статическое поле lines типа List<LineItem>, которое сразу проинициализировано.
4. В методе main(String[] args) программа должна считывать имена файлов с консоли (используй BufferedReader).
5. В методе main(String[] args) BufferedReader для считывания данных с консоли должен быть закрыт.
6. Программа должна считывать содержимое первого и второго файла (используй FileReader).
7. Потоки чтения из файлов (FileReader) должны быть закрыты.
8. Список lines должен содержать объединенную версию строк из файлов, где для каждой строки указана одна из операций ADDED, REMOVED, SAME.
строка6
строка2
строка7
строка3
строка8
строка4
строка9
строка5
строка10
строка1
строка11
строка2
строка12
строка3
строка2
строка3
строка4
строка5
строка1
строка2
строка3
строка5
*/