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

Сортировка массива структур по выбранному полю с помощью алгоритма std::sort

28.10.2011, 19:22. Показов 4130. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Не знаю, как правильно передать функцию сравнения в std::sort.
Кроме того в моей структуре есть поля одного типа, мне кажется будет не правильно писать одинаковые функции сравнения для каждого поля.
Вот структура моей программы:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
struct HOUSE{
    string street;
    string number;
    string num_floors;
    string num_apartment;
    int num_residents;
 
};
template <class T_str>
class A{
public:
    T_str mas[100];
    sort_ist(/*sor принять ф-ю сравнения*/){std::sort(bud,buf+100,sor);}
};
 
class B{
public:
    A<HOUSE> test;
    bool sor(string a,string b){return a<b;}//НЕ ПРАВИЛЬНО //функция сравнения 
 
    void fsort(){ test.sort_ist(/*тут должен передать по какому полю сортировать*/) }
};
Тут эта тема поднималась, но я не смог разобраться http://www.rsdn.ru/forum/cpp/1030325.flat.aspx
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
28.10.2011, 19:22
Ответы с готовыми решениями:

Сортировка массива структур с помощью Array.Sort
struct myArray { public int Numb; } class Program { static void Main(string args) { ...

Std::min_element по заданному полю массива структур
Есть структура Point{double x,y}. Есть вектор vector&lt;Point&gt;. Как правильно определить функцию сравнения точек по заданной координате...

Сортировка массива c++ std :: sort()
Дан двумерный массив символов char M, надо отсортировать его при помощи std :: sort(), построчно, т.е. допустим было 00011 11111 ...

1
В астрале
Эксперт С++
 Аватар для ForEveR
8049 / 4806 / 655
Регистрация: 24.06.2010
Сообщений: 10,562
28.10.2011, 20:14
Не будет он так сортировать. Перегрузите для структуры оператор < тогда да.

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
struct HOUSE{
        string street;
        string number;
        string num_floors;
        string num_apartment;
        int num_residents;
 
};
template <class T_str>
class A{
public:
        T_str mas[100];
        template<class Predicate>
        sort_ist(Predicate sor){std::sort(bud,buf+100,sor);}
};
 
class B{
public:
        A<HOUSE> test;
        bool sor(const T_str& a, const T_str& b){return a<b;}//НЕ ПРАВИЛЬНО //функция сравнения 
 
        void fsort(){ test.sort_ist(/*тут должен передать по какому полю сортировать*/) }
};
Добавлено через 3 минуты
Или в sor явно указывайте поля. К примеру.
C++
1
return a.street < b.street;
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
28.10.2011, 20:14
Помогаю со студенческими работами здесь

Сортировка массива структур по полю
Дана структура: struct elecHelp1 { char fio, name, sname, nameElection, constituensy; double help_percent; int numVotes; }; ...

Сортировка массива структур по полю
Здравствуйте! Условие: Для книг, хранящихся в библиотеке, задаются регистрационный номер книги, автор, название, год издания,...

Сортировка массива с использованием алгоритма стандартной библиотеки шаблонов Sort()
6.Напишите программу на языке программирования С++, сортирующую массив с использованием алгоритма стандартной библиотеки шаблонов sort().

Сортировка массива структур по заданному полю
Здравствуйте. Нужна помощь в сортировке. Вот само задание: Составить таблицу, содержащую следующие сведения о сотрудниках кафедры: ...

Сортировка массива структур по заданному полю
Добрый день. Я начинаю изучать C# и мне в качестве учебной задачи нужно сделать сортировку массива структур по заданному полю. В примере...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru