Если я в строке 41 заменю метод isGreaterThan на StringList.get(j).length() > StringList.get(j+1).length(), то все сортируется правильно.
package com.javarush.task.task09.task0930;
import java.io.BufferedReader;
import java.io.InputStreamReader;
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[0]);
sort(array);
for (String x : array) {
System.out.println(x);
}
}
public static void sort(String[] array) throws Exception {
ArrayList<Integer> IntList = new ArrayList<>();
ArrayList<String> StringList = new ArrayList<>();
for (int i = 0; i < array.length; i++) {
if (isNumber(array[i])) IntList.add(Integer.parseInt(array[i]));
else StringList.add(array[i]);
}
for(int i = StringList.size()-1 ; i > 0 ; i--){
for(int j = 0 ; j < i ; j++){
if(isGreaterThan(StringList.get(j),StringList.get(j+1)) ){
String tmp = StringList.get(j);
StringList.set(j, StringList.get(j+1));
StringList.set(j+1, tmp);
}
System.out.println(StringList);
}
}
Collections.sort(IntList);
Collections.reverse(IntList);
System.out.println(StringList);
System.out.println(IntList);
int j = -1;
int v = -1;
for (int i = 0; i < array.length; i++) {
if (isNumber(array[i])) {
IntList.add(1);
j++;
array[i] = String.valueOf(IntList.get(j));
}
}
for (int i = 0; i < array.length; i++) {
if (!isNumber(array[i])) {
System.out.println(StringList);
StringList.add("d");
v++;
array[i] = StringList.get(v);
}
}
}
// Метод для сравнения строк: 'а' больше чем '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;
}
}