Собственно в чем идея:
Я так и не придумал как не создавая новые списки сортировать исходный массив.
Создал 2 списка.
Гоню исходный массив через isNumber, если возврат true, то добавляю число в новый список num.
Если нет, добавляю в новый список text.
Сортирую num, делаю реверс, с числами готово.
Дальше беру список text и пытаюсь пользуясь isGreaterThan(text.get(j), text.get(j + 1) отсортировать список, но не выходит, дайте идею.
package com.javarush.task.task09.task0930;
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.util.ArrayList;
import java.util.Collections;
/*
Задача по алгоритмам Ӏ Java Syntax: 9 уровень, 11 лекция
*/
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> num = new ArrayList<>();
ArrayList<String > text = new ArrayList<>();
for(String s : array){
if(isNumber(s)){
int x = Integer.parseInt(s);
num.add(x);
}
else text.add(s);
}
Collections.sort(num);
Collections.reverse(num);
//сортировка текста
for(int i = text.size()-1; i>0; i--){
for (int j = 0 ; j < i ; j++) {
if (isGreaterThan(text.get(j), text.get(j + 1))) {
String tmp = text.get(j);
text.add(j+1, text.get(j));
text.add(j+1, tmp);
}
}
}
for(int i=0; i<text.size(); i++){
System.out.println(text.get(i));
}
for(int i = 0; i<num.size();i++){
System.out.println(num.get(i));
}
}
// Метод для сравнения строк: 'а' больше чем '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;
}
}