Advertisement
Not a member of Pastebin yet?
Sign Up,
it unlocks many cool features!
- import java.io.BufferedReader;
- import java.io.InputStreamReader;
- import java.util.ArrayList;
- /* Задача по алгоритмам
- Задача: Пользователь вводит с клавиатуры список слов (и чисел). Слова вывести в возрастающем порядке, числа - в убывающем.
- Пример ввода:
- Вишня
- 1
- Боб
- 3
- Яблоко
- 2
- 0
- Арбуз
- Пример вывода:
- Арбуз
- 3
- Боб
- 2
- Вишня
- 1
- 0
- Яблоко
- */
- 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>();
- while (true)
- {
- String s = reader.readLine();
- if (s.isEmpty()) break;
- list.add(s);
- }
- String[] array = list.toArray(new String[list.size()]);
- sort(array);
- for (String x : array)
- {
- System.out.println(x);
- }
- }
- public static void sort(String[] array)
- {
- ArrayList<Integer> listNumbers = new ArrayList<Integer>();
- ArrayList<Integer> listWord = new ArrayList<Integer>();
- for (int k = 0; k < array.length; k++)
- {
- if (isNumber(array[k])) // Якщо число - записує порядековий номер в масив
- {
- listNumbers.add(k);
- }
- else { // Якщо слово - записує порядковий номер в масив
- listWord.add(k);
- }
- }
- for (int i = 0; i < array.length; i++) // Проганяю всі елементи масиву
- {
- for (int j = 0; j < listNumbers.size() - 1; j++)
- {
- if (Integer.parseInt(array[listNumbers.get(j)]) < Integer.parseInt(array[listNumbers.get(j + 1)])) // сортування для Чисел
- {
- String s = array[listNumbers.get(j + 1)];
- array[listNumbers.get(j + 1)] = array[listNumbers.get(j)];
- array[listNumbers.get(j)] = s;
- }
- }
- for (int f = 0; f < listWord.size() - 1; f++ ) // сортування для слів
- {
- if (isGreaterThen(array[listWord.get(f)], array[listWord.get(f + 1)]))
- {
- String s = array[listWord.get(f + 1)];
- array[listWord.get(f + 1)] = array[listWord.get(f)];
- array[listWord.get(f)] = s;
- }
- }
- }
- }
- // Зрівнюю слова (чи а більше б) (цей метод вже був написаний в умові)
- public static boolean isGreaterThen(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 != '-') ) // не цифра і не починається з '-' (цей метод вже був написаний в умові)
- {
- return false;
- }
- }
- return true;
- }
- }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement