Программа компилируется, запускается, проверку не проходит. Пишет, что слишком долго исполняется.
package com.javarush.task.task09.task0930;
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.lang.reflect.AnnotatedArrayType;
import java.sql.SQLOutput;
import java.util.ArrayList;
/*
Задача по алгоритмам
*/
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<Integer> indexnumber = new ArrayList<>();
ArrayList<Integer> number = new ArrayList<>();
ArrayList<Integer> indexstring = new ArrayList<>();
ArrayList<String> str = new ArrayList<String>();
for (int i = 0; i < array.length; i++) {
if (isNumber(array[i])) {
indexnumber.add(i);
number.add(Integer.parseInt(array[i]));
}
else {
indexstring.add(i);
str.add(array[i]);
}
}
Integer[] numberm = number.toArray(new Integer[0]);
String[] strm = str.toArray(new String[0]);
boolean x = true;
while(x) {
x = false;
for (int i = 1; i < strm.length; i++) {
if (isGreaterThan(strm[i - 1], strm[i])) {
String temp = strm[i - 1];
strm[i - 1] = strm[i];
strm[i] = temp;
x = true;
}
}
}
x = true;
while(x) {
for (int i = numberm.length - 1; i > 0; i--) {
x = false;
if (numberm[i - 1] < numberm[i]) {
int temp = numberm[i - 1];
numberm[i - 1] = numberm[i];
numberm[i] = temp;
x = true;
}
}
}
for (int i = 0; i < indexnumber.size(); i++) {
array[indexnumber.get(i)] = Integer.toString(numberm[i]);
}
for (int i = 0; i < indexstring.size(); i++) {
array[indexstring.get(i)] = strm[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;
}
}