Помогите в концовке, уже сил нет писать сортировку чисел, воспользовался методом Collection.reverse, но он как-то не так сортирует. По логике: программа проходит все элементы array и если там число запихивает в arraylist number, если нет то line. после чего их сортирует каждый (number не удалось отсортировать). После чего пробегается заново по array и если там число- последовательно перезаписывает числа из отсортированного массива,если слово, то из отсортированного массива слов.
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.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) {
ArrayList<Integer> numbposition =new ArrayList<>();
ArrayList<String> number= new ArrayList<>();
ArrayList<Integer> lineposition =new ArrayList<>();
ArrayList<String> line= new ArrayList<>();
for (int i=0;i<array.length;i++){
if ((isNumber(array[i]))==true) {numbposition.add(i); number.add(array[i]);}
else { lineposition.add(i);line.add(array[i]);}
}
Collections.reverse(number);
boolean flag=true;
while(flag){
flag=false;
for (int i=0;i<line.size()-1;i++) {
if (isGreaterThan(line.get(i), line.get(i + 1)) == true){ Collections.swap(line,i,i+1); flag=true;}
}
}
int j=0;
int q=0;
for (int i=0;i<array.length;i++) {
if((isNumber(array[i]))==true) {array[i]=number.get(j);j++;}
else {array[i]=line.get(q);q++;}
}
System.out.println(number);
System.out.println(line);
}
// Метод для сравнения строк: 'а' больше чем '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;
}
}