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

Как отсортировать массив строк по нескольким полям

12.11.2019, 22:05. Показов 2547. Ответов 9

Студворк — интернет-сервис помощи студентам
Есть структура со следующими данными: ФИО рабочего, продолжительность опоздания:
-Нужно ввести данные в массив;
-Отсортировать по следующим полям:
1) по фамилии рабочих
2) по убыванию продолжительности опоздания
-Вывести все данные
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
12.11.2019, 22:05
Ответы с готовыми решениями:

Как отсортировать массив по нескольким ключам?
Есть выборка из БД, возвращающая список страниц. Выборка отсортирована по дате их создания. Необходимо отсортировать её ещё сначала по...

Как фильтровать товары по нескольким полям?
Здравствуйте, подскажите как можно сделать так, чтобы фильтр был не взаимоисключающим? Т.е. чтобы можно было комбинировать, например...

Как осуществить суммирование в БД по нескольким полям?
Приветствую! Есть БД. В ней 3 поля: Номер вызывающего абонента, Номер вызываемого абонента, Продолжительность разговора. Любой абонент...

9
0 / 0 / 0
Регистрация: 10.10.2019
Сообщений: 22
12.11.2019, 22:54  [ТС]
Есть структура со следующими данными: ФИО рабочего, продолжительность опоздания:
-Нужно ввести данные в массив;
-Отсортировать по следующим полям:
1) по фамилии рабочих
2) по убыванию продолжительности опоздания
-Вывести все данные
0
736 / 700 / 110
Регистрация: 29.05.2015
Сообщений: 4,282
12.11.2019, 23:19
Вопрос имеет смысл только в том случае, если в списке есть однофамильцы, и тогда фамилии сортируются по алфавиту, а однофамильцы в свою очередь - уже по времени опоздания.

Если ближе к кодированию, то наверное нужно создавать двумерный список (список списков), и сортировать внешний список по ФИО, а вложенные - по опозданию. И затем последовательно выводить на экран.
0
0 / 0 / 0
Регистрация: 10.10.2019
Сообщений: 22
12.11.2019, 23:37  [ТС]
alexu_007, пожалуйста помогите это реализовать
0
Мозгоправ
 Аватар для L0M
1745 / 1039 / 468
Регистрация: 01.10.2018
Сообщений: 2,138
Записей в блоге: 2
12.11.2019, 23:53
Лучший ответ Сообщение было отмечено hazard11 как решение

Решение

hazard11,
C++
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
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
#include <iostream>
#include <string>
#include <algorithm>
#include <iterator>
 
using namespace std;
 
struct Stukailo {
    string fio;
    int lateness;
};
 
ostream& operator << (ostream& os, const Stukailo& st) {
    return os << "(" << st.fio << " - " << st.lateness << ")";
}
 
const size_t N = 10;
 
int main()
{
    Stukailo arr[N] = {
        { "zzz", 5 },
        { "sss", 3 },
        { "aaa", 1 },
        { "mmm", 8 },
        { "xxx", 2 },
        { "zzz", 3 },
        { "sss", 6 },
        { "aaa", 2 },
        { "mmm", 4 },
        { "xxx", 1 }
    };
 
    // по ФИО
    sort(arr, arr + N, [](const Stukailo& lh, const Stukailo& rh) { return lh.fio < rh.fio; });
    copy(arr, arr + N, ostream_iterator<Stukailo>(cout, "\n"));
    cout << endl;
 
    // по убыванию продолжительности опоздания
    sort(arr, arr + N, [](const Stukailo& lh, const Stukailo& rh) { return lh.lateness > rh.lateness; });
    copy(arr, arr + N, ostream_iterator<Stukailo>(cout, "\n"));
    cout << endl;
 
    // сначала по ФИО, потом по убыванию продолжительности опоздания
    sort(arr, arr + N, [](const Stukailo& lh, const Stukailo& rh) { return (lh.fio == rh.fio) ? lh.lateness > rh.lateness : lh.fio < rh.fio; });
    copy(arr, arr + N, ostream_iterator<Stukailo>(cout, "\n"));
    cout << endl;
 
    return 0;
}
1
0 / 0 / 0
Регистрация: 10.10.2019
Сообщений: 22
13.11.2019, 00:04  [ТС]
Спасибо, только данные структуры нужно заполнить с клавиатуры
0
Мозгоправ
 Аватар для L0M
1745 / 1039 / 468
Регистрация: 01.10.2018
Сообщений: 2,138
Записей в блоге: 2
13.11.2019, 01:21
Цитата Сообщение от hazard11 Посмотреть сообщение
только данные структуры нужно заполнить с клавиатуры
Основу я вам написал, а дальше уж вы как-нибудь сами.
1
736 / 700 / 110
Регистрация: 29.05.2015
Сообщений: 4,282
13.11.2019, 08:18
А смысл? Один рабочий не может опоздать два раза. Сортировать полных тёзок (с одинаковыми ФИО) по времени?
0
0 / 0 / 0
Регистрация: 10.10.2019
Сообщений: 22
13.11.2019, 19:38  [ТС]
можете удалять уже сделал
0
0 / 0 / 0
Регистрация: 10.10.2019
Сообщений: 22
13.11.2019, 19:38  [ТС]
спасибо, можете удалять уже доделал
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
13.11.2019, 19:38
Помогаю со студенческими работами здесь

Как сделать поиск по нескольким полям?
Я уже искал различные темы, и в интернете искал. Но я не понимаю того что там пишут. Вернее поисковик не совсем правильно работает как...

Фильтрация по нескольким полям как в интернет магазинах
как реализовать фильтр по набору данных, например, как на сайте яндекс маркет. там фильтрация выглядит следующим образом. например, хотим...

Как связать две таблицы по нескольким полям?
Нужно, что бы работала связь Master-Detail. Но связать таблицы можно только сразу по двум полям, т.к. только в паре получается уникальная ...

Как отсортировать массив строк из БД
Здравствуйте! Есть функция, которая возвращает строку из БД MS SQL, она запускается в цикле for, тоесть каждый раз по 1 строке возвращает и...

Как вносить данные в объект сразу по нескольким полям за один раз
Всем привет, допустим, хочу вносить данные в объект в консоли вот так Имя...(курсор здесь и здесь вношу) Фамилия...(потом могу ...


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

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Новые блоги и статьи
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru