В методе main я не менял условие выхода из цикла. Но когда вводишь пустую строку программа продолжает запросы... По этой причине валидатор выдал: "Программа работала слишком долго и была закрыта!". Если вводить только числа, то программа работает как надо.
package com.javarush.task.task09.task0930;
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.sql.SQLOutput;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collections;
/*
Задача по алгоритмам
*/
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[list.size()]);
sort(array);
for (String x : array) {
System.out.println(x);
}
}
public static void sort(String[] array) {
// напишите тут ваш код
ArrayList<String> strings = new ArrayList<>(); //Список слов.
ArrayList<Integer> numbers = new ArrayList<>(); //Список чисел.
ArrayList<Integer> numbersIndex = new ArrayList<>(); //Список индексов чисел в массиве.
for (String s : array) {
if (isNumber(s)) { //Если число,
numbers.add(Integer.parseInt(s)); //добавляем его в список чисел
numbersIndex.add(Arrays.asList(array).indexOf(s)); //и сохраняем его индекс.
}
else //Иначе
strings.add(s); //добавляем в список слов.
}
Collections.sort(numbers); //Сортируем список чисел в порядке убывания.
Collections.reverse(numbers);
int i = 1;
while (i < strings.size()) { //Сортируем список слов в порядке возростания.
if (i == 0 || isGreaterThan(strings.get(i), strings.get(i - 1)))
i++;
else {
String temp = strings.get(i);
strings.add(i, strings.get(i - 1));
strings.add(i - 1, temp);
}
}
int n = 0;
int s = 0;
for (int j = 0; j < array.length; j++) { //Сортируем массив по условию
if (j == numbersIndex.get(n)) {
array[j] = String.valueOf(numbers.get(n));
n++;
} else {
array[j] = strings.get(s);
s++;
}
}
}
// Метод для сравнения строк: 'а' больше чем '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;
}
}