В общем, я решил что я самый умный (лол) и нафиг использовать isGreaterThan когда можно не использовать.
В итоге у меня получился вот такой код:
Строки 28-30 закомментил пока проверяю вывод. Если раскомментить - они выводят то же самое что введено, не применяя сортировку.
Строки 78-80 выводят всё так, как надо и в нужном порядке. Добавил чтоб проверить.
Вопрос: как передать отсортированный массив наверх при таком раскладе?
Извиняюсь если вопрос тупой, но я уже полдня сижу и мозг отказывается работать.
P.S. Спасибо, я знаю что без isGreaterThan проверка не примет задачу. Но для галочки использовать метод просто чтоб прошло проверку я умею.
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;
import java.util.Comparator;
import java.util.Iterator;
/*
Задача по алгоритмам
*/
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) 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<String> words = new ArrayList<String>();
ArrayList<Integer> numbers = new ArrayList<Integer>();
for (int i = 0; i < array.length; i++) {
String a = array[i];
if (isNumber(a)) {
int b = Integer.parseInt(a);
numbers.add(b);
}
else words.add(a);
}
// сортируем слова
String[] words2 = words.toArray(new String[words.size()]);
Arrays.sort(words2);
// сортируем цифры
Integer[] numbers2 = numbers.toArray(new Integer[numbers.size()]);
Arrays.sort(numbers2);
int temp;
int n = numbers2.length;
for (int i = 0; i < n/2; i++) {
temp = numbers2[n-i-1];
numbers2[n-i-1] = numbers2[i];
numbers2[i] = temp;
}
// сливаем в один массив
ArrayList<String> result = new ArrayList<String>();
int dlina = ((words2.length + numbers2.length) / 2);
for (int i = 0; i < dlina; i++) {
String word = words2[i];
result.add(word);
String number = Integer.toString(numbers2[i]);
result.add(number);
}
// проверяем что массив собрался так, как надо. Закомментить перед проверкой следующие 3 строки
for (String x : result) {
System.out.println(x);
}
}
// Метод для сравнения строк: 'а' больше чем '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;
}
}