|
8 / 8 / 6
Регистрация: 02.04.2014
Сообщений: 62
|
|||||||||||||||||||||
Шаблон функции сортировки массива структур по разным типам полей04.04.2014, 13:35. Показов 10549. Ответов 12
Метки нет (Все метки)
Делаю лабу.
Вот текст задания. Считайте все записи из файла "1.dat". Для чтения каждой отдельной записи осуществите динамический захват памяти. Предполагается, что к-во записей в файле заранее неизвестно. Выполните сортировку записей по различным ключам: · по фамилии (по возрастанию); · по дате рождения (по возрастанию); · по окладу (по убыванию). Для каждого ключа используйте различные алгоритмы сортировки: · сортировка выбором, · сортировка вставками, · сортировка Шелла, · быстрая сортировка. Всего сортировка будет выполнена 12 раз, каждый раз сортируется массив в первоначальном состоянии. Для каждого случая подсчитайте к-во сравнений и перестановок. Оцените скорость, естественность и устойчивость каждого алгоритма. Оптимальную организацию функций продумайте самостоятельно. Неделю уже ломаю голову не могу придумать "Оптимальную организацию" шаблонов функций сортировки (
Но это же ужас, на каждое сортируемое поле (3 поля) писать 4 вида функций сортировки, итого 3 * 4 = 12 !!! Есть ли из моего тупика другой выход? P.S. Классы, string, перегрузку операторов, алгоритмы из STL и прочие новомодные навороты НЕ предлагать - этого мы еше НЕ проходили. Добавлено через 2 часа 0 минут наверное выход есть? штудирую счас указатели на функции и что-то смутное у меня вырисовывается типа как работает стандартная функцией qsort() у нее есть параметр на функцию сравнения, возможно это выход для меня, написать три перегруженные функции сравнения:
типа так:
Подумал еще и, блин, опять засада: а что подставить на место параметров функции *(pf_compare)(note a[], ?..) в шаблоне?
как жить с такими проблемами!!! думаю дальше, думаю............... Добавлено через 4 минуты у меня пока с указателями БЕДА! каша полная в голове )
0
|
|||||||||||||||||||||
| 04.04.2014, 13:35 | |
|
Ответы с готовыми решениями:
12
Шаблон функции сортировки массива
|
|
Полярный
477 / 449 / 158
Регистрация: 11.09.2011
Сообщений: 1,156
|
|||
| 04.04.2014, 13:42 | |||
|
определенный интеграл на указанном пользователем промежутке Там самый последний код. Вкратце - имеются 4 формулы (в Вашем случае - 3 ключа) и 3 метода (в Вашем случае - 4 метода сортировки), юзер выбирает формулу и метод, программа использует указатели и выдает результат. Удачи.
1
|
|||
|
19491 / 10097 / 2460
Регистрация: 30.01.2014
Сообщений: 17,805
|
||||||||
| 04.04.2014, 14:27 | ||||||||
![]() ![]()
1
|
||||||||
|
8 / 8 / 6
Регистрация: 02.04.2014
Сообщений: 62
|
|||||||
| 04.04.2014, 17:20 [ТС] | |||||||
|
DrOffset,
пошел по твоему пути крутил я в параметрах и note и конкретные поля и нифига не идет ( блин, котелок уже не варит! запутался я увы, знаний пока маловато ну приведу полный код, на всякий, может быть кто ткнет меня носом в мою ошибку ... Кликните здесь для просмотра всего текста
Добавлено через 11 минут в 107 строке компилятор (VS 2013) ругается так e:\anton\vs\vc++\семестр 2\5\1\1.cpp(135): error C2784: void selection_sort(T [],int,int,int (__cdecl *)(item &,item &)): не удалось вывести аргумент шаблон для "перегруженный тип функции" из "перегруженный тип функции" Добавлено через 45 секунд перемудрил я что-то (
0
|
|||||||
|
19491 / 10097 / 2460
Регистрация: 30.01.2014
Сообщений: 17,805
|
||
| 04.04.2014, 17:28 | ||
0
|
||
|
8 / 8 / 6
Регистрация: 02.04.2014
Сообщений: 62
|
|
| 04.04.2014, 17:35 [ТС] | |
|
вот всплывающая подсказка компилятора на ошибку
0
|
|
|
8 / 8 / 6
Регистрация: 02.04.2014
Сообщений: 62
|
|
| 04.04.2014, 17:36 [ТС] | |
|
я уже сегодня не соображаю )
0
|
|
|
19491 / 10097 / 2460
Регистрация: 30.01.2014
Сообщений: 17,805
|
|||||||
| 04.04.2014, 17:38 | |||||||
Сообщение было отмечено don_keyhot как решение
Решение
Вот поправил, но не компилировал и не проверял. Если что - спрашивай.
Кликните здесь для просмотра всего текста
Добавлено через 1 минуту
1
|
|||||||
|
8 / 8 / 6
Регистрация: 02.04.2014
Сообщений: 62
|
||
| 04.04.2014, 17:58 [ТС] | ||
|
большое спасибо, счас проверю, хех, энергия появляется, усталость уходит )
Добавлено через 18 минут DrOffset, да уж, сколько у меня там было ошибок! спасибо! ну правда после сортировки, уже на выходе выскакивает ошибка, но мы с этим уже сами справимся, надеюсь )
1
|
||
|
8 / 8 / 6
Регистрация: 02.04.2014
Сообщений: 62
|
||||||
| 15.04.2014, 15:47 [ТС] | ||||||
|
вот черновик пока для одного типа сортировки:
0
|
||||||
|
0 / 0 / 0
Регистрация: 05.09.2019
Сообщений: 27
|
|
| 02.04.2020, 19:58 | |
|
DrOffset, Итераторы (пример использования итератора для шаблона, к примеру списка) тут ты написал код на тему итераторы. Очень сложная для меня тема. Очень прошу ,напиши комментарии к своему коду. Пожалуйста
0
|
|
| 02.04.2020, 20:24 | |
|
Не по теме: DarkPo13, пока что не понятно что именно там комментировать? Подписать конструктору, что он конструктор?
0
|
|
|
0 / 0 / 0
Регистрация: 05.09.2019
Сообщений: 27
|
|
| 03.04.2020, 13:41 | |
|
DrOffset, этот код предназначен для односвязного списка? Если да,то как сделать для двусвязного?
0
|
|
| 03.04.2020, 13:41 | |
|
Помогаю со студенческими работами здесь
13
Шаблон функции с разным возвращаемым типом Как оформить операцию создания (формирования) массива структур из 5 полей (фамилия, имя, улица, дом, квартира) в виде функции?
Сократить код, несколько раз приводящий объект к разным типам
Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
||||
|
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение.
И на уровне агентов добавится между грибами или бактериями взаимодействий.
До того я пробовал подход через многомерные массивы,. . .
|
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути
Programma_Boinc 01.01.2026
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути
Сочетание глобально распределённой вычислительной мощности и инновационных. . .
|
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Налог на собак: https:/ / **********/ gallery/ V06K53e
Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf
Пост отсюда. . .
|
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop?
Ниже её машинный перевод.
После долгих разбирательств я наконец-то вернула себе. . .
|
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод
Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод.
Thinkpad X220 Tablet —. . .
|
|
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-динозавры, а новое поколение лёгких потоков. Откат?. . .
|