????
Везде компилируется , кроме здесь :)
package com.javarush.task.task09.task0930;
import java.io.BufferedReader;
import java.io.*;
import java.util.*;
/*
Задача по алгоритмам Ӏ Java Syntax: 9 уровень, 11 лекция
*/
public class Solution {
static List<Integer> il;
static List<String> sl;
public static void main(String[] args) throws Exception, NullPointerException {
BufferedReader reader = new BufferedReader(new InputStreamReader(System.in));
ArrayList<String> list = new ArrayList<>();
il= new ArrayList<>();
sl= new ArrayList<>();
while (true) {
String s = reader.readLine();
if (s.equals("")) {
//list.remove(list.size()-1);
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) {
// напишите тут ваш код
List<String> newList = new ArrayList<>();
for(int i=0;i<array.length;i++){
if(isNumber(array[i])){
il.add(Integer.parseInt(array[i]));
}else{
sl.add(array[i]);
}
}
for(int i=sl.size()-1;i>0;i--){
for(int j =1;j<sl.size();j++){
if(isGreaterThan(sl.get(j-1),sl.get(j))){
String temp = sl.get(j-1);
sl.set(j-1,sl.get(j));
sl.set(j,temp);
}
if(il.size()>3){
if(il.get(j)>il.get(j-1)){
int tmp=il.get(j-1);
il.set(j-1,il.get(j));
il.set(j,tmp);
}
}
}
}
//Collections.sort(il) ;
//Collections.reverse(il);
for(int i=0,j=0,k=0;i<array.length;i++){
if(isNumber(array[i])){
array[i]=String.valueOf(il.get(j));
j++;
} else{
array[i]=sl.get(k);
k++;
}
}
// System.out.println(array.length);
}
// Метод для сравнения строк: 'а' больше чем '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;
}
}