?
package com.javarush.task.task09.task0930;
import java.io.*;
import java.util.*;
/*
Задача по алгоритмам
*/
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==null||s.isEmpty()) {
break;
}
list.add(s);
}
String[] array = new String[list.size()];
list.toArray(array);
sort(array);
for (String x : array) {
System.out.println(x);
}
}
public static void sort(String[] array) {
for(int i=array.length-1;i>0;i--){
for(int j=0;j<i;j++)
{if(isNumber(array[j]))
{int u = nextIntJ(array,j);
if(u<array.length&&Integer.parseInt(array[j])>Integer.parseInt(array[u]))
{String tmp = array[j];
array[j] = array[u];
array[u] = tmp;}
}
else
{int y = nextStringJ(array,j);
if(y<array.length&&isGreaterThan(array[j],array[y]))
{String tmp1 = array[j];
array[j] = array[y];
array[y] = tmp1;}}
}
}
}
// Метод для получения следующего числового элемента массива
public static int nextIntJ(String[] array,int j) {
int next = array.length;
for(int i=j+1;i<array.length;i++)
{if(isNumber(array[i])) next = i;break;}
return next;
}
// Метод для получения следующего строкового элемента массива
public static int nextStringJ(String[] array,int j) {
int next = array.length;
for(int i=j+1;i<array.length;i++)
{if(!isNumber(array[i])) next = i;break;}
return next;
}
// Метод для сравнения строк: 'а' больше чем '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;
}
}