Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.90/29: Рейтинг темы: голосов - 29, средняя оценка - 4.90
5 / 3 / 1
Регистрация: 06.11.2014
Сообщений: 33

Как использовать std::find_if?

11.11.2014, 20:52. Показов 5451. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день!

Хочу использовать find_if, в реализации сортировки вставками. Но с синтаксисом у меня проблема. Помогите исправить код
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
// Used in insertion sort.
// Inserts *(end - 1) into sorted array [*beg; *(end -1) ).
template <typename T, class Itor, class Cmp>
void insert_element(Itor beg, Itor end, Cmp cmp) {
    if (beg == end) {
        return;
    }
    T element = *(std::prev(end));
    Itor correct_location = std::find_if(beg, end, 
        [] (T array_elem) { return cmp(element, array_elem); });
    while (--end != correct_location) {
        *end = *(std::prev(end));
    }
    *end = element;
}
Соответственно, текущий вердикт - error C3493: "cmp" нельзя передать неявно, поскольку не задан режим передачи по умолчанию
Строка 10.
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
11.11.2014, 20:52
Ответы с готовыми решениями:

Error in std::find_if
Привет всем. Подскажите плз. Что std::find_if не поддерживает обратных итераторов? Почему этот код вызывает ошибку компиляции? ...

Как можно еще использовать std::placeholders вне в связки с std::bind?
Добрый день! Как можно еще использовать std::placeholders вне в связки с std::bind?

Что использовать, std::cout или просто using namespace std?
Приветствую! Сейчас учу С++, постигаю азы так сказать. В арсенале две книги - Джефф Кент, &quot;Основы программирования &quot; и...

4
Вездепух
Эксперт CЭксперт С++
 Аватар для TheCalligrapher
12938 / 6805 / 1821
Регистрация: 18.10.2014
Сообщений: 17,224
11.11.2014, 21:09
Лучший ответ Сообщение было отмечено КамазПодарков как решение

Решение

Цитата Сообщение от КамазПодарков Посмотреть сообщение
error C3493:
Если лямбда-функция задана со списком захвата '[]', то это означает, что функция ничего не захватывает вообще. В такой лямбда-функции запрещается доступаться как каким-либо внешним объектам.

В данном случае лямбде нужны 'cmp' и 'element'

C++
1
2
    Itor correct_location = std::find_if(beg, end, 
        [&cmp, &element] (T array_elem) { return cmp(element, array_elem); });
ну или просто

C++
1
2
    Itor correct_location = std::find_if(beg, end, 
        [&] (T array_elem) { return cmp(element, array_elem); });
Или, раз уж вы параметр в лямбду передаете по значению, а не по ссылке, то может быть и все остальное хотите захватывать по значению? Тогда вместо '&' будет '='.

В чем смысл вот этой загадочной манипуляции

C++
1
2
3
    while (--end != correct_location) {
        *end = *(std::prev(end));
    }
мне не ясно. Чем это отличается от прямого 'end = correct_location;'?
1
5 / 3 / 1
Регистрация: 06.11.2014
Сообщений: 33
11.11.2014, 21:21  [ТС]
TheCalligrapher, пасибо!

Добавлено через 2 минуты
Цитата Сообщение от TheCalligrapher Посмотреть сообщение
В чем смысл вот этой загадочной манипуляции
Смысл сдвинуть хвост вектора влево, а на нужное место засунуть элемент.

Добавлено через 1 минуту
вправо, а не влево, путаю их))
0
Вездепух
Эксперт CЭксперт С++
 Аватар для TheCalligrapher
12938 / 6805 / 1821
Регистрация: 18.10.2014
Сообщений: 17,224
11.11.2014, 21:31
Цитата Сообщение от КамазПодарков Посмотреть сообщение
Смысл сдвинуть хвост вектора влево,
Ой, что-то я брежу. Конечно, это ничуть не эквивалентно 'end = correct_location;'.

В приниципе, разу уж вы пользуетесь 'std::find_if', то почему бы не воспользоваться 'std::copy_backward' для выполнения сдвига, вместо того, чтобы выписывать его руками?

C++
1
std::copy_backward(correct_location, std::prev(end), end);
0
5 / 3 / 1
Регистрация: 06.11.2014
Сообщений: 33
11.11.2014, 22:03  [ТС]
Потому как не знал, что такая есть, спасибо попробую)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
11.11.2014, 22:03
Помогаю со студенческими работами здесь

Использовать using namespace std; или каждый раз прописывать std:: . ?
Как безопаснее и рациональнее поступать? Как в больших проектах поступают на этот счет?

Не получается использовать std::copy как memcpy?
Получил задание переписать свою код: Поля x, y указывают координаты, куда должен быть помещен файл - кадр, а width, height ширину и...

Как использовать std::wstring для удаление файлов
Если можно, пожалуйста, приведите код.

Показать на примере, как использовать манипулятор std::ws класса istream
Здравствуйте, уважаемые форумчане! Пожалуйста, объясните и, если можно, покажите на примере, как использовать манипулятор std::ws класса...

Как минимально просто использовать функция std::find с последовательность типа : list<myClass*>
Добрый день. Как минимально просто использовать функция std::find с последовательность типа : list&lt;myClass*&gt;,если в классе перегружен...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь 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. На борту пять. . .
Камера 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. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru