Сортирует неверно, хотя ошибок в коде не вижу.
Заранее благодарю за подсказку.
package com.javarush.task.task09.task0930;
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.util.ArrayList;
/*
Задача по алгоритмам Ӏ 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<>();
String line = reader.readLine();
while (!line.isEmpty()) {
list.add(line);
line = reader.readLine();
}
String[] array = list.toArray(new String[0]);
sort(array);
for (String x : array) {
System.out.println(x);
}
}
public static void sort(String[] array) {
// напишите тут ваш код
for (int i=0; i<array.length-1; i++) {
for (int j=0; j<array.length-1; j++) {
if (!isNumber(array[i])) {
if (!isNumber(array[j+1])) {
if (isGreaterThan(array[i], array[j+1])) {
swap(array, i, j);
}
}
else {
if (isNumber(array[j+1])) {
if (Integer.parseInt(array[j+1]) > Integer.parseInt(array[i])) {
swap(array, i, j);
}
}
}
}
}
} ;
}
// Метод для сравнения строк: 'а' больше чем 'b'
public static boolean isGreaterThan(String a, String b) {
return a.compareTo(b) > 0;
}
// Переданная строка - это число?
public static boolean isNumber(String text) {
if (text.length() == 0) {
return false;
}
char[] chars = text.toCharArray();
for (int i = 0; i < chars.length; i++) {
char character = chars[i];
// есть '-' внутри строки
if (i != 0 && character == '-') {
return false;
}
// не цифра и не начинается с '-'
if (!Character.isDigit(character) && character != '-') {
return false;
}
// одиночный '-'
if (chars.length == 1 && character == '-') {
return false;
}
}
return true;
}
public static void swap(String[] array, int i, int j) {
String tmp = array[j+1];
array[j+1] = array[i];
array[i] = tmp;
}
}
else
на 39 строке, является частью оператораif (!isNumber(array[j+1]))
расположенного на 34 строке, а не частью оператораif (!isNumber(array[i]))
расположенного на 33 строке. Кроме этого, у Вас не верно реализован алгоритм сортировки вставками: например если взять массив чисел{1, 2, 3, 4}
(каюсь, был невнимателен и в своём прошлом комментарии привёл неверные примеры массивов), то на выходе вашего методаsort
, после того как исправите проблему со скобками, получится следующий массив{4, 1, 3, 2}
. Так произойдёт потому, что, когдаi
станет равно2
, аj
будет равным0
, число3
поменяется местами с числом1
. Давайте представим состояния массива при каждом обмене: