|
1 / 1 / 0
Регистрация: 23.05.2017
Сообщений: 12
|
|
Лямбда функция (или нет) для сортировки12.10.2019, 16:11. Показов 7666. Ответов 16
Метки нет (Все метки)
Привет
В общем, нужно сделать лабу в институте, ничего как всегда не объясняют, просто нужно сделать: Задача: Сигнатура функции сортировки: Template<typename T> Sequence<T>* Sort(Sequence<T>* seq, int (*cmp)(T,T)); Вопрос: что такое int (*cmp)(T,T) ? то ли какая-то лямбда функция, то ли указатель на функцию... Как я понял, cmp - compare, мол нужно, чтобы можно было выбрать как сортировать: по возрастанию, убыванию Собственно, как реализовать это, как определить эту функцию, и лямбда ли это? Спасибо)
0
|
|
| 12.10.2019, 16:11 | |
|
Ответы с готовыми решениями:
16
Лямбда выражения для сортировки коллекции Создал код для сортировки медотом пузырька цикл идёт, а сортировки нет Есть ли функция для определения - восходящий график или нет? |
|
24 / 14 / 10
Регистрация: 11.08.2019
Сообщений: 59
|
|||||||||||
| 12.10.2019, 16:27 | |||||||||||
|
YzxI,
Добавлено через 5 минут Я только недавно прочитал об этом, и в том материале использовали функтор, именуемый бинарным предикатом, т.е. объект с такой сигнатурой вызова
0
|
|||||||||||
|
1 / 1 / 0
Регистрация: 23.05.2017
Сообщений: 12
|
||||||
| 12.10.2019, 16:30 [ТС] | ||||||
|
ddvamp1, спасибо, читаю об этом, но всё еще не могу понять, как мне банально вызвать хоть как-то эту функцию?
Вот, допустим есть такая болванка:
0
|
||||||
|
фрилансер
6455 / 5656 / 1129
Регистрация: 11.10.2019
Сообщений: 15,064
|
||||||
| 12.10.2019, 16:30 | ||||||
|
ddvamp1, YzxI, а лямбду здесь можно так задать
0
|
||||||
|
24 / 14 / 10
Регистрация: 11.08.2019
Сообщений: 59
|
|||||||||||||||||
| 12.10.2019, 16:35 | |||||||||||||||||
Сообщение было отмечено YzxI как решение
Решение
1
|
|||||||||||||||||
|
1 / 1 / 0
Регистрация: 23.05.2017
Сообщений: 12
|
||||||
| 12.10.2019, 16:41 [ТС] | ||||||
|
Алексей1153, ddvamp1, не компилится (
minGW
0
|
||||||
|
фрилансер
6455 / 5656 / 1129
Регистрация: 11.10.2019
Сообщений: 15,064
|
|
| 12.10.2019, 16:46 | |
|
YzxI, у тебя лямбда возвращает тип bool, а сигнатура аргумента func хочет int
и ещё опечатка в сигнатуре - скобок не хватает void func(int (*cmp)(int, int)){
1
|
|
|
1 / 1 / 0
Регистрация: 23.05.2017
Сообщений: 12
|
|
| 12.10.2019, 16:47 [ТС] | |
|
Алексей1153, ой, зевнул.. поменял на return 1;
та же ошибка
0
|
|
|
24 / 14 / 10
Регистрация: 11.08.2019
Сообщений: 59
|
|
| 12.10.2019, 16:48 | |
|
0
|
|
|
фрилансер
6455 / 5656 / 1129
Регистрация: 11.10.2019
Сообщений: 15,064
|
||||||
| 12.10.2019, 16:52 | ||||||
Сообщение было отмечено YzxI как решение
Решение
YzxI,
1
|
||||||
|
1 / 1 / 0
Регистрация: 23.05.2017
Сообщений: 12
|
||||||
| 12.10.2019, 16:53 [ТС] | ||||||
|
ddvamp1, хах, действительно! так вот для чего скобка нужна была...
Спасибо, ddvamp1, Алексей1153, А теперь, например, чтобы сделать сортировку по убыванию или возрастанию, я должен вызывать тип такого:
0
|
||||||
|
24 / 14 / 10
Регистрация: 11.08.2019
Сообщений: 59
|
||||||
| 12.10.2019, 17:00 | ||||||
|
И да, т.к. в return логическое выражение возвращаемый тип вычисляется как bool, нужно использовать так называемый хвостовой возвращаемый тип
1
|
||||||
|
1 / 1 / 0
Регистрация: 23.05.2017
Сообщений: 12
|
|
| 12.10.2019, 17:02 [ТС] | |
|
ddvamp1,
0
|
|
|
24 / 14 / 10
Регистрация: 11.08.2019
Сообщений: 59
|
|
| 12.10.2019, 17:04 | |
|
YzxI, если вы прочитали, то что я писал про ваше последние сообщение, то там неверно, я не разобрался, что у вас вызов вашей функции sort, лямбды у вас аргументы, так что все верно, вроде бы)
Только вы забыли '}' в конце обоих лямбд, и не нужно писать ';' после return 1
0
|
|
|
1 / 1 / 0
Регистрация: 23.05.2017
Сообщений: 12
|
|
| 12.10.2019, 17:08 [ТС] | |
|
ddvamp1, ага, всё работает)
0
|
|
|
24 / 14 / 10
Регистрация: 11.08.2019
Сообщений: 59
|
||||||
| 12.10.2019, 17:09 | ||||||
YzxI, замечательно!)
0
|
||||||
|
1 / 1 / 0
Регистрация: 23.05.2017
Сообщений: 12
|
|
| 12.10.2019, 17:09 [ТС] | |
|
ddvamp1, точняк, так короче, и без -> int
![]()
0
|
|
| 12.10.2019, 17:09 | |
|
Помогаю со студенческими работами здесь
17
Inline функция или нет Функция для сортировки файла
Функция Compare для стандартной сортировки Функция для сортировки массива пузырьком Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так:
https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347
Основана на STM32F303RBT6.
На борту пять. . .
|
Символьное дифференцирование
igorrr37 13.02.2026
/ *
Программа принимает математическое выражение в виде строки и выдаёт его производную в виде строки и вычисляет
значение производной при заданном х
Логарифм записывается как: (x-2)log(x^2+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 с альфа-каналом (с прозрачным. . .
|