Помогите пожалуйста разобраться, не проходит проверку 4-й пункт: Выведенные числа должны быть упорядочены по убыванию(входные данные были изменены), хотя результат выдает правильно, запутался совсем.
package com.javarush.task.task09.task0930;
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.util.ArrayList;
/*
Задача по алгоритмам
*/
public class Solution {
private static ArrayList<Integer> arrayList1 = new ArrayList<>();
private static ArrayList<String> arrayList2 = new ArrayList<>();
private static ArrayList<Integer> arrayList3 = new ArrayList<>();
private static ArrayList<String> arrayList4 = new ArrayList<>();
private static boolean isSorted1 = false;
private static boolean isSorted2 = false;
private static String buf1;
private static String buf2;
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) {
for (int i = 0; i < array.length; i++) {
if (isNumber(array[i])){
arrayList1.add(i);
arrayList2.add(array[i]);
}
else {
arrayList3.add(i);
arrayList4.add(array[i]);
}
}
while (! isSorted1) {
isSorted1 = true;
for (int i = 0; i < arrayList2.size() - 1; i++) {
if ((Integer.valueOf(arrayList2.get(i)) < Integer.valueOf(arrayList2.get(i + 1)))){
isSorted1 = false;
buf1 = arrayList2.get(i);
arrayList2.set(i, arrayList2.get(i + 1));
arrayList2.set(i + 1, buf1);
}
}
}
while (! isSorted2) {
isSorted2 = true;
for (int i = 0; i < arrayList4.size() - 1; i++) {
if (isGreaterThan(arrayList4.get(i), arrayList4.get(i + 1))){
isSorted2 = false;
buf2 = arrayList4.get(i);
arrayList4.set(i, arrayList4.get(i + 1));
arrayList4.set(i + 1, buf2);
}
}
}
arrayList1.addAll(arrayList3);
arrayList2.addAll(arrayList4);
for (int i = 0; i < array.length; i++) {
array[arrayList1.get(i)] = arrayList2.get(i);
}
}
// Метод для сравнения строк: 'а' больше чем '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;
}
}