package com.javarush.task.task09.task0930;
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.Map;
/*
Задача по алгоритмам
*/
public class Solution {
public static ArrayList<String> str = new ArrayList<>();
public static ArrayList<Integer> ch = new ArrayList<>();
public static boolean[] flags ;
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]);
flags = new boolean[array.length];
sort(array);
int ich=0; int istr =0;
for (int i=0; i<flags.length; i++) {
if(flags[i] == true)
{
System.out.print(ch.get(ich));
//array[i] = ch.get(ich);
ich++;
}
else
{
System.out.print(str.get(istr));
//array[i] = str.get(istr);
istr++;
}
if ( i != flags.length-1)
{
System.out.println();
}
}
/* for (String s : array) {
System.out.println(s);
}*/
}
public static void sort(String[] array) {
boolean b = isGreaterThan("a","b");
for (int i=0; i<array.length; i++) {
if(isNumber(array[i]) == true)
{
ch.add(Integer.parseInt(array[i]));
flags[i] = true;
}
else
{
str.add(array[i]);
flags[i] = false;
}
}
for (int j = 0; j < ch.size(); j++) {
{
for (int i = 0; i < ch.size()-1; i++) {
if(ch.get(i)<ch.get(i+1))
{
Integer a = ch.get(i);
ch.set(i, ch.get(i+1));
ch.set(i+1, a);
}
}
}
}
for (int j = 0; j < str.size(); j++) {
{
for (int i = 0; i < str.size()-1; i++) {
if(isGreaterThan(str.get(i), str.get(i+1)))
{
String a = str.get(i);
str.set(i, str.get(i+1));
str.set(i+1, a);
}
}
}
}
}
// Метод для сравнения строк: 'а' больше чем '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;
}
}
Anton
35 уровень
Валидатор выдает ошибку "Выведенные числа должны быть упорядочены по убыванию." комментирует : Входящие данные были изменены. Все перепробовал, все обсуждения смотрел, а все равно не проходит. все тесты проходит правильно
Решен
Комментарии (2)
- популярные
- новые
- старые
Для того, чтобы оставить комментарий Вы должны авторизоваться
Сергеев ВикторMaster
12 августа 2019, 17:12решение
не используйте статические переменные
+2
Anton
13 августа 2019, 12:34
Большое спасибо! Помогло!
0