Advertisement
Not a member of Pastebin yet?
Sign Up,
it unlocks many cool features!
- 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<>();
- while (true) {
- String s = reader.readLine();
- if (s.isEmpty()) {
- 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<Integer> numbers = new ArrayList<>();
- ArrayList<String> strings = new ArrayList<>();
- for (int i = 0; i < array.length ; i++) {
- String str = array[i];
- if (isNumber(str))
- numbers.add(Integer.parseInt(str));
- else
- strings.add(str);
- }
- String[] strArray = new String[strings.size()];
- for (int i = 0; i < strings.size(); i++) {
- strArray[i] = strings.get(i);
- }
- //-------------------------------------------------------
- int[] numbersArray = new int[numbers.size()];
- for (int i = 0; i <numbers.size(); i++) {
- numbersArray[i] = numbers.get(i);
- }
- for (int i = 0; i < strArray.length ; i++) { // OK
- String strRight = strArray[i];
- for (int j = i - 1; j >= 0 ; j--) {
- String strLeft = strArray[j];
- if (isGreaterThan(strLeft, strRight)) {
- strArray[j+1] = strLeft;
- strArray[j] = strRight;
- }
- }
- }
- for (int i = 0; i < numbersArray.length; i++) {
- int rightNumbers = numbersArray[i];
- for (int j = i - 1; j >= 0 ; j--) {
- int leftNumbers = numbersArray[j];
- if (leftNumbers < rightNumbers) {
- numbersArray[j + 1] = leftNumbers;
- numbersArray[j] = rightNumbers;
- }
- }
- }
- //----------------------------------------------------
- String[] fromNumtoString = new String[numbersArray.length];
- for (int i = 0; i < numbersArray.length; i++) {
- fromNumtoString[i] = String.valueOf(numbersArray[i]);
- }
- int num = 0;
- int str = 0;
- for (int i = 0; i < array.length; i++) {
- if (isNumber(array[i])) {
- array[i] = fromNumtoString[num];
- num++;
- }
- else {
- array[i] =strArray[str];
- str++;
- }
- }
- }
- // Метод для сравнения строк: 'а' больше чем '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;
- }
- }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement