Форум программистов, компьютерный форум, киберфорум
Java для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.69/75: Рейтинг темы: голосов - 75, средняя оценка - 4.69
0 / 0 / 0
Регистрация: 09.03.2018
Сообщений: 118

Сортировка ArrayList по полю объекта

28.06.2019, 18:16. Показов 14013. Ответов 20
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Есть класс:
Java
1
2
3
4
public class Word {
    String content;
    int frequency;
}
Как отсортировать ArrayList, содержащий объекты этого класса, по полю frequency, а если она совпадает, то в лексикографическом порядке?
Кликните здесь для просмотра всего текста
Пример:

инпут:
asd 43 asdf asd 43
434 asdf
kasdf asdf

оутпут:
asdf : 3
43 : 2
asd : 2
434 : 1
kasdf : 1
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
28.06.2019, 18:16
Ответы с готовыми решениями:

Доступ к полю объекта в ArrayList
Здравствуйте, у меня есть ArrayList объектов Device(); Как обратиться к полям объекта Device() в ArrayList? public class Device { ...

сортировка элементов объекта по заданному полю
У меня есть массив объектов: let objArray = ; Его надо отсортировать по заданному полю (конкретно по клику в таблице на заголовок). ...

Сортировка данных объекта по одному полю
Мне нужно сделать сортировку в лексикографическом порядке mass -массив строк Что я делаю не так? StringArray *mass5 = new...

20
 Аватар для Goongala
1022 / 562 / 185
Регистрация: 18.08.2013
Сообщений: 2,027
Записей в блоге: 2
28.06.2019, 18:50
Почитай про интерфейс Comparator

Добавлено через 1 минуту
Ну, либо Comparable, если хош этот метод сортировки именно в класс запихать
0
Эксперт PythonЭксперт Java
19530 / 11067 / 2931
Регистрация: 21.10.2017
Сообщений: 23,294
28.06.2019, 20:45

Не по теме:

Цитата Сообщение от griezzie7 Посмотреть сообщение
инпут:
asd 43 asdf asd 43
434 asdf
kasdf asdf
оутпут:
asdf : 3
43 : 2
asd : 2
434 : 1
kasdf : 1
Что за дичь?



Java
1
2
3
4
list.stream()
        .sorted(Comparator.comparing(Word::getFrequency)
                .thenComparing(Word::getContent))
        .forEach(System.out::println);
1
0 / 0 / 0
Регистрация: 09.03.2018
Сообщений: 118
28.06.2019, 20:47  [ТС]
iSmokeJC, программа должна выводить слова и частоту этих слов в убывающем порядке
0
Эксперт PythonЭксперт Java
19530 / 11067 / 2931
Регистрация: 21.10.2017
Сообщений: 23,294
28.06.2019, 20:55
Цитата Сообщение от griezzie7 Посмотреть сообщение
программа должна выводить слова и частоту этих слов в убывающем порядке
Как это можно было угадать из
Цитата Сообщение от griezzie7 Посмотреть сообщение
Как отсортировать ArrayList, содержащий объекты этого класса, по полю frequency, а если она совпадает, то в лексикографическом порядке
?
0
0 / 0 / 0
Регистрация: 09.03.2018
Сообщений: 118
28.06.2019, 22:51  [ТС]
iSmokeJC, можете объяснить, как работает этот код, а то не пойму выкрутасы с двоеточиями(
0
 Аватар для Goongala
1022 / 562 / 185
Регистрация: 18.08.2013
Сообщений: 2,027
Записей в блоге: 2
28.06.2019, 23:11
griezzie7, эт лямба-выражение. Тип, для каждого объекта в листе вызывается метод getFrequency

Добавлено через 1 минуту
ну и сравнивается значение, которое он возвратил
0
0 / 0 / 0
Регистрация: 09.03.2018
Сообщений: 118
28.06.2019, 23:11  [ТС]
Gungala, а почему выводит типа сам объект, а не сами поля?
0
 Аватар для Goongala
1022 / 562 / 185
Регистрация: 18.08.2013
Сообщений: 2,027
Записей в блоге: 2
28.06.2019, 23:13
griezzie7, потому что метод вывода вызывается для объектов, а не полей
Java
1
.forEach(System.out::println);
0
0 / 0 / 0
Регистрация: 09.03.2018
Сообщений: 118
28.06.2019, 23:14  [ТС]
Gungala, понимаю, что тупой вопрос, но как вывести поля?
0
 Аватар для Goongala
1022 / 562 / 185
Регистрация: 18.08.2013
Сообщений: 2,027
Записей в блоге: 2
28.06.2019, 23:14
Если хош, чтоб выводились поля, можно что-то такое написать
Java
1
.forEach(i -> System.out.println(i.getContent() + " : " + i.getFrequency()));
Добавлено через 19 секунд
Хых, опередил твою мысль, но поздно отправил
1
0 / 0 / 0
Регистрация: 09.03.2018
Сообщений: 118
28.06.2019, 23:20  [ТС]
Gungala, все равно как-то не так сортирует, цифры должны первыми быть, если частота одинаковая, как это реализовать?
0
 Аватар для Goongala
1022 / 562 / 185
Регистрация: 18.08.2013
Сообщений: 2,027
Записей в блоге: 2
28.06.2019, 23:27
Попробуй заменить на это
Java
1
2
3
4
5
6
7
8
.sorted((w1, w2) -> {
int w1_fr = w1.getFrequency();
int w2_fr = w2.getFrequency();
if (w1_fr != w2_fr)
return w1_fr - w2_fr;
else
return w1.getContent().compareTo(w2.getContent());
})
0
0 / 0 / 0
Регистрация: 09.03.2018
Сообщений: 118
28.06.2019, 23:31  [ТС]
Gungala, все равно по-старому выдаёт
0
 Аватар для Goongala
1022 / 562 / 185
Регистрация: 18.08.2013
Сообщений: 2,027
Записей в блоге: 2
28.06.2019, 23:34
griezzie7, уф, покажи, что выдаёт и исправь таким образом, шоб было, как ты хочешь, а то я тебя не понимаю, видимо
0
0 / 0 / 0
Регистрация: 09.03.2018
Сообщений: 118
28.06.2019, 23:36  [ТС]
Gungala, как должно
asdf : 3
43 : 2
asd : 2
434 : 1
kasdf : 1

как выводит
asdf : 3
asd : 2
43 : 2
kasdf : 1
434 : 1
0
 Аватар для Goongala
1022 / 562 / 185
Регистрация: 18.08.2013
Сообщений: 2,027
Записей в блоге: 2
28.06.2019, 23:47
Лучший ответ Сообщение было отмечено griezzie7 как решение

Решение

griezzie7, попробуй это
Java
1
2
        .sorted(Comparator.comparing(Word::getFrequency).reversed()
                .thenComparing(Word::getContent))
1
0 / 0 / 0
Регистрация: 09.03.2018
Сообщений: 118
28.06.2019, 23:49  [ТС]
Gungala, уф, жоско, спасибо
0
 Аватар для Goongala
1022 / 562 / 185
Регистрация: 18.08.2013
Сообщений: 2,027
Записей в блоге: 2
28.06.2019, 23:55
griezzie7, обращайся (⌐■_■)
0
Эксперт функциональных языков программированияЭксперт Java
 Аватар для korvin_
4575 / 2773 / 491
Регистрация: 28.04.2012
Сообщений: 8,760
29.06.2019, 01:12
Цитата Сообщение от Gungala Посмотреть сообщение
эт лямба-выражение
Нет. Это method reference.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
29.06.2019, 01:12
Помогаю со студенческими работами здесь

Сортировка массива по любому полю объекта
Мне нужно, чтобы можно было выбрать по какому полю объекта будет идти сортировка массива. Массив объектов состоит из трех полей, отображен...

Spring JPA сортировка по полю вложенного объекта
Spring JPA сортировка по полю вложенного объекта Как мне желательно при помощи Spring JPA или компаратора, отобрать все объекты...

Сортировка структуры по полю Tag и по полю Eng
Есть структура: struct _1C { string Tag; string Rus; string Eng; _1C(const string &Tag, const string &Rus, const string...

Удаление объекта из ArrayList
Здравствуйте! У меня есть класс,c следующими полями class Sportsmen { string last_name; string...

Ошибка с записью объекта в ArrayList
Создал класс с конструктором public class Time_Table extends Activity { String depart, arrived, date; int cost, id; ...


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

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru