Всем привет. Помогите победить валидатор. Выдает ошибку:Ты не отсортировал слова по возрастанию.
Сколько ни проверял - код работает без сбоев, слова сортируются пузырьком. Числа через коллекции
package com.javarush.task.task09.task0930;
import java.io.BufferedReader;
import java.io.InputStreamReader;
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 s : array)
System.out.println(s);
}
public static void sort(String[] array) {
//Распределение общего массива по 2 массивам: числовому и строковому
ArrayList<Integer> numbers = new ArrayList<>();
ArrayList<String> strings = new ArrayList<>();
for (int i = array.length - 1; i >= 0; i--) {
if (isNumber(array[i])) {
numbers.add(Integer.parseInt(array[i]));
} else
strings.add(array[i]);}
//Сортировка строкового массива пузырьком
boolean isSorted = false;
String buf = null;
while (!isSorted)
isSorted = true;
for (int i = 0; i < strings.size() - 1; i++) {
if (isGreaterThan(strings.get(i), strings.get(i + 1))) {
isSorted = false;
buf = strings.get(i);
strings.set(i, strings.get(i + 1));
strings.set(i + 1, buf);
}
}
//Сортировка числового массива
Collections.sort(numbers);
Collections.reverse(numbers);
//СОединение 2 листов в изначальный массив array
int index_string = 0;
int index_number = 0;
for (int i = 0; i < array.length; i++) {
if (isNumber(array[i])) {
array[i] = numbers.get(index_number).toString();
index_number++;
} else {
array[i] = strings.get(index_string);
index_string++;
}
}
}
// Метод для сравнения строк: 'а' больше чем '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;
}
}
package com.javarush.task.task09.task0930;
import java.io.BufferedReader;
import java.io.InputStreamReader;
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 s : array)
System.out.println(s);
}
//Распределение общего массива по 2 массивам: числовому и строковому
public static void sort(String[] array) {
// напишите тут ваш код
ArrayList<Integer> numbers = new ArrayList<>();
ArrayList<String> strings = new ArrayList<>();
for (int i = array.length - 1; i >= 0; i--) {
if (isNumber(array[i])) {
numbers.add(Integer.parseInt(array[i]));
} else
strings.add(array[i]);}
//Сортировка строкового массива пузырьком
boolean isSorted = false;
String buf = null;
while (!isSorted)
isSorted = true;
for (int i = 0; i < strings.size() - 1; i++) {
if (isGreaterThan(strings.get(i), strings.get(i + 1))) {
isSorted = false;
buf = strings.get(i);
strings.set(i, strings.get(i + 1));
strings.set(i + 1, buf);
}
}
//Сортировка числового массива
Collections.sort(numbers);
Collections.reverse(numbers);
int index_string = 0;
int index_number = 0;
for (int i = 0; i < array.length; i++) {
if (isNumber(array[i])) {
array[i] = numbers.get(index_number).toString();
index_number++;
} else {
array[i] = strings.get(index_string);
index_string++;
}
}
}
// Метод для сравнения строк: 'а' больше чем '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;
}
}