Форум программистов, компьютерный форум, киберфорум
Java SE (J2SE)
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.71/7: Рейтинг темы: голосов - 7, средняя оценка - 4.71
0 / 0 / 0
Регистрация: 24.05.2015
Сообщений: 86

Не могу реализовать простой компаратор

28.11.2019, 12:20. Показов 1476. Ответов 3

Студворк — интернет-сервис помощи студентам
Первый раз пишу простой компаратор и возникла проблема.
Хочу сделать вывод таким, чтобы сначала выводились четные числа в порядке возрастания, а затем нечетные в порядке возрастания. Из ввода 5 2 1 6 3 4 я хочу получить 2 4 6 1 3 5, но получаю 2 6 4 5 3 1.
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
public class Priority {
    public static void main(String[] args) {
        Queue<Integer> queue = new PriorityQueue<>(new Comparator<Integer>() {
            @Override
            public int compare(Integer o1, Integer o2) {
                if (o1%2==0 && o2%2==0){
                    return o1.compareTo(o2);
                }
                else if (o1%2==0 && o2%2!=0){
                    return -1;
                }
                else if (o1%2!=0 && o2%2==0){
                    return 1;
                }
                else return o1.compareTo(o2);
            }
        });
        queue.add(5);
        queue.add(2);
        queue.add(1);
        queue.add(6);
        queue.add(3);
        queue.add(4);
        System.out.println(queue);
    }
}
Кажется, логику понял правильно, но реализовать не получается.
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
28.11.2019, 12:20
Ответы с готовыми решениями:

Не могу понять на что способен sort, и что делает его компаратор
Недавно мой знакомый рассказывал что-то про sort,говорил что с помощью него можно сортировать как хочешь и что хочешь,с сортировкой qSort и...

Реализовать простой расчет
Добрый день! Подскажите, кто знает, мне необходимо реализовать простой расчет допустим есть данные double j=3.2, k=2.1, i=3.4; ...

Реализовать простой графический редактор
Здравствуйте добрые пользователи этого сайта. Помогите мне ,человеку который в этом нифига не разбирается ,создать простой графический...

3
 Аватар для sdasdaw
406 / 278 / 93
Регистрация: 14.03.2017
Сообщений: 777
28.11.2019, 14:13
hsad, проблема queuepriority. Он не проверяет последний элемент при сравнении, а только делает это когда мы пытаемся взять элемент из него (некая оптимизация)

Если хотите упорядоченную очередь, то как вариант:
Кликните здесь для просмотра всего текста
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
List<Integer> list = new ArrayList(Arrays.asList(5, 2, 1, 6, 3, 4));
 
Collections.sort(list, new Comparator<Integer>() {
    @Override
    public int compare(Integer o1, Integer o2) {
        return (o1 - o2) % 2 == 0 ?
                o1.compareTo(o2)
                :
                o1 % 2 == 0 ?
                        -1
                        :
                        1;
    }
});
 
Queue<Integer> queue = new PriorityQueue<>(new Comparator<Integer>() {
    @Override
    public int compare(Integer o1, Integer o2) {
        return 1;
    }
});
queue.addAll(list);
 
System.out.println(queue);


Иначе, просто берите элементы из этой очереди и получите то что нужно:
Java
1
2
3
while (!queue.isEmpty()) {
    System.out.println(queue.poll());
}
И проверку можно модифицировать:
Java
1
2
3
4
5
6
7
8
9
Queue<Integer> queue = new PriorityQueue<>(
    (o1, o2) -> (o1 - o2) % 2 == 0 ?
                        o1.compareTo(o2)
                        :
                        o1 % 2 == 0 ?
                                -1
                                :
                                1
);
1
Эксперт Java
3639 / 2971 / 918
Регистрация: 05.07.2013
Сообщений: 14,220
28.11.2019, 14:33
Лучший ответ Сообщение было отмечено HighPredator как решение

Решение

Java
1
2
3
4
5
6
7
8
9
10
11
12
Comparator<Integer> oddComparator = Comparator.comparingInt(o -> o % 2);
        Queue<Integer> queue = new PriorityQueue<>(oddComparator.thenComparing(Comparator.naturalOrder()));
        queue.add(5);
        queue.add(2);
        queue.add(1);
        queue.add(6);
        queue.add(3);
        queue.add(4);
        Integer i;
        while ((i = queue.poll())!=null) {
            System.out.println(i);
        }
3
 Аватар для Aviz__
2741 / 2050 / 507
Регистрация: 17.02.2014
Сообщений: 9,470
29.11.2019, 14:25
Цитата Сообщение от sdasdaw Посмотреть сообщение
(o1 - o2) % 2 == 0
это свойство чисел, я и забыл((.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
29.11.2019, 14:25
Помогаю со студенческими работами здесь

Как реализовать простой таймер?
простая программка 2 кнопки. старт и стоп. когда нажимаеш кнопку старт то каждую секунду должно выполняться какое-то действие, например...

Реализовать простой графический редактор
Доброго времени суток. Я совсем недолго изучаю Java. Задача стоит реализовать простой графический редактор. Создал на панели инструментов...

Как реализовать простой heap
Помогите написать класс, который представляет heap и реализует четыре метода AllocTinyHeap() - Создает heap с заданным количеством байтов...

Реализовать самый простой чат
Здравствуйте. Мне нужно реализовать самый простой чат на си, под линуксом. есть кое-какие наработки сервера и клиента (не обошлось без...

Как реализовать простой поиск по записям БД
Здравствуйте! Мне нужно сделать программу, в которой можно было бы найти информацию. То есть вводишь например фамилию и тебе выдает его...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru