Подскажите, в чем может быть ошибка?
package com.javarush.task.task09.task0930;
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.util.ArrayList;
/*
Задача по алгоритмам Ӏ Java Syntax: 9 уровень, 11 лекция
*/
public class Solution {
public static void main(String[] args) throws Exception {
BufferedReader reader = new BufferedReader(new InputStreamReader(System.in));
ArrayList<String> list = new ArrayList<>();
while (true) {
String s = reader.readLine();
if (s.isEmpty()) {
break;
}
list.add(s);
}
String[] array = list.toArray(new String[0]);
sort(array);
for (String x : array) {
System.out.println(x);
}
}
public static void sort(String[] array) {
// напишите тут ваш код
ArrayList<String> numbers = new ArrayList<>();
ArrayList<String> words = new ArrayList<>();
for (String value : array) { //делим на 2 массива (числа и строки)
if (isNumber(value)) {
numbers.add(value);
} else {
words.add(value);
}
}
String tmp;
for (int i = 0; i < numbers.size(); i++) { //сортируем массив чисел
String s1 = numbers.get(i);
String s2 = numbers.get(i + 1);
boolean num = isGreaterThan(s1, s2);
if (!num) {
tmp = s1;
numbers.add(i,s2);
numbers.add(i+1,tmp);
}
}
String tmp1;
for (int i = 0; i < words.size(); i++) { //сортируем массив строк
String s1 = words.get(i);
String s2 = words.get(i + 1);
boolean num = isGreaterThan(s1, s2);
if (num) {
tmp1 = s1;
numbers.add(i,s2);
numbers.add(i+1,tmp1);
}
}
int countNum = 0; //пытаемся раставить значения (цифры и строки) по местам
int countWord = 0;
for (int i = 0; i < array.length; i++) {
if (isNumber(array[i])) {
String s = numbers.get(countNum);
array[i] = s;
countNum++;
} else {
String s = words.get(countWord);
array[i] = s;
countWord++;
}
}
}
// Метод для сравнения строк: 'а' больше чем 'b'
public static boolean isGreaterThan(String a, String b) {
return a.compareTo(b) > 0;
}
// Переданная строка - это число?
public static boolean isNumber(String s) {
if (s.length() == 0) {
return false;
}
char[] chars = s.toCharArray();
for (int i = 0; i < chars.length; i++) {
char c = chars[i];
if ((i != 0 && c == '-') // Строка содержит '-'
|| (!Character.isDigit(c) && c != '-') // или не цифра и не начинается с '-'
|| (chars.length == 1 && c == '-')) // или одиночный '-'
{
return false;
}
}
return true;
}
}