package com.javarush.task.task09.task0930;
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.util.ArrayList;
/*
Задача по алгоритмам
*/
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 s;
while (true) {
s = reader.readLine();
if (s.isEmpty()) {
break;
} else {
list.add(s);
}
}
String[] array = list.toArray(new String[0]);
sort(array);
for (String x : array) {
System.out.println(x);
}
}
private static void sort(String[] array) {
ArrayList<Integer> numbers = new ArrayList<>();
ArrayList<String> strings = new ArrayList<>();
String buffS;
int countInts = 0, countStrings = 0, buffI;
//разделяем исходный массив по 2м типовым
for (String s: array) {
if (isNumber(s)) { // || s.equals("0")
numbers.add(Integer.parseInt(s));
}
else {
strings.add(s);
}
}
//сортируем строки
for (int i = 0; i < strings.size(); i++) {
for (int j = strings.size() - 1; j > 0; j--) {
if (isGreaterThan(strings.get(j - 1), strings.get(j))) {
buffS = strings.get(j - 1);
strings.set(j - 1, strings.get(j));
strings.add(j, buffS);
}
}
}
//сортируем числа
for (int i = 0; i < numbers.size(); i++) {
for (int j = numbers.size() - 1; j > 0; j--) {
if (numbers.get(j - 1) < numbers.get(j)) {
buffI = numbers.get(j - 1);
numbers.set(j - 1, numbers.get(j));
numbers.add(j, buffI);
}
}
}
//вставляем новые значения вместо старых
for (int i = 0; i < array.length; i++) {
if (isNumber(array[i])) {
array[i] = Integer.toString(numbers.get(countInts));
countInts++;
}
else {
array[i] = strings.get(countStrings);
countStrings++;
}
}
}
// Метод для сравнения строк: 'а' больше чем '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;
}
}
Aleksandr
11 уровень
Отказывает на этапе ввода пустой строки в примере из задания к задаче
Решен
Комментарии (6)
- популярные
- новые
- старые
Для того, чтобы оставить комментарий Вы должны авторизоваться
Valery Lvov
22 октября 2019, 07:14
Ввод строк, в т.ч. пустой, вроде б правильно написан. У меня также, и работало (единственное отличие - list.add вынес в Else)
0
IceBergMaster
21 октября 2019, 17:53
В браузере решаешь? Попробуй "".equals(s)
0
Aleksandr
21 октября 2019, 18:13
решаю в Idea и не помогло. :( причём на валидаторе тоже виснет: "Программа работала слишком долго и была закрыта!"
0
IceBergMaster
21 октября 2019, 18:24
Тут бесконечный цикл, add выращивает size.
+1
Aleksandr
21 октября 2019, 18:57решение
В сортировке чисел та же болячка. Я сам уже увидел через нотирование сорта, а потом посекционно пробором через трай/кечь :) Но спасибо за помощь.
+2
IceBergMaster
21 октября 2019, 19:02
Лучше потрать время на понимание работы дебагера, в противном случае в 10 раз больше времени потратишь на эти танцы с нотированием и ловлей исключений.
0