0 / 0 / 0
Регистрация: 01.03.2016
Сообщений: 42
|
||||||
1 | ||||||
Std::sort сортировка вектора объектов22.10.2018, 18:56. Показов 3282. Ответов 17
Метки нет (Все метки)
Добрый день. Пытаюсь выполнить сортировку вектора объектов с помощью функции сравнения
ошибка1: "CirclesContainer::Greater": нестандартный синтаксис; используйте "&", чтобы создать указатель на член, ошибка2: "sort" требует аргументов: 2, имеется: 3, не найдена соответствующая перегруженная функция Почему sort не признает третий аргумент? Что не так? И как надо? Помогите, пожалуйста.
0
|
22.10.2018, 18:56 | |
Ответы с готовыми решениями:
17
Сортировка вектора через std::sort Почему стандартная сортировка вектора std::sort намного быстрее сортировки вставками/пузырьком? Сортировка массива c++ std :: sort() Сортировка индексов алгоритмом std::sort |
184 / 192 / 48
Регистрация: 25.08.2011
Сообщений: 792
|
||||||
22.10.2018, 19:01 | 2 | |||||
0
|
0 / 0 / 0
Регистрация: 01.03.2016
Сообщений: 42
|
|
22.10.2018, 19:09 [ТС] | 3 |
без амперсандов ошибки остаются точно такими же (выше).
А в источнике использовались именно амперсанды... https://www.codeproject.com/Ar... on#funcptr
0
|
184 / 192 / 48
Регистрация: 25.08.2011
Сообщений: 792
|
||||||
22.10.2018, 19:15 | 4 | |||||
Сообщение было отмечено RedSkyWalker как решение
Решение
забиндить попробуйте
Добавлено через 4 минуты
но амперсенди там не нужни
0
|
0 / 0 / 0
Регистрация: 01.03.2016
Сообщений: 42
|
|
22.10.2018, 19:15 [ТС] | 5 |
поподробнее если можно, что это значит "забиндить"? я просто в С++ новичок.
ага вижу
0
|
184 / 192 / 48
Регистрация: 25.08.2011
Сообщений: 792
|
|
22.10.2018, 19:21 | 6 |
Ви не путайте там персон передаеться по рефернсу а у вас по указателю нет смисла передавать указатель по константной ссилке.
Добавлено через 4 минуты там _1 _2 правку добавил забиваю что Ви не в курсе)
0
|
0 / 0 / 0
Регистрация: 01.03.2016
Сообщений: 42
|
|
22.10.2018, 19:33 [ТС] | 7 |
а что за параметры - _1,_2 ?
0
|
184 / 192 / 48
Регистрация: 25.08.2011
Сообщений: 792
|
||||||
22.10.2018, 19:36 | 8 | |||||
1
|
0 / 0 / 0
Регистрация: 01.03.2016
Сообщений: 42
|
|
22.10.2018, 20:12 [ТС] | 9 |
Теперь запускается без ошибок, большое спасибо! Но не сортирует, думаю дело в том, что поле radius в метод Greater подставляется от абстрактного родительского класса Shape, вместо того, чтобы подставляться от наследника... а у Shape radius=0. В С++ можно переопределить поле абстрактного класса в наследниках как-то?
Т.е. процесс сортировки идет, но неправильно
0
|
184 / 192 / 48
Регистрация: 25.08.2011
Сообщений: 792
|
|
22.10.2018, 20:21 | 10 |
дайте полный код
0
|
0 / 0 / 0
Регистрация: 01.03.2016
Сообщений: 42
|
|
22.10.2018, 21:01 [ТС] | 11 |
отправил в личку
0
|
184 / 192 / 48
Регистрация: 25.08.2011
Сообщений: 792
|
|
22.10.2018, 21:21 | 12 |
ответил в личке
0
|
0 / 0 / 0
Регистрация: 01.03.2016
Сообщений: 42
|
|||||||||||
22.10.2018, 21:44 [ТС] | 13 | ||||||||||
Сообщение от 1Вирт1
0
|
184 / 192 / 48
Регистрация: 25.08.2011
Сообщений: 792
|
|||||||||||
22.10.2018, 21:50 | 14 | ||||||||||
0
|
0 / 0 / 0
Регистрация: 01.03.2016
Сообщений: 42
|
|
22.10.2018, 21:57 [ТС] | 15 |
)) ну почти. Компилируется, но сортирует все равно криво. Радиусы 20, 19 и 17 выдал в порядке: 17, 20, 19 )
Добавлено через 2 минуты Отладка показывает, что получаемые значения rA и rB равны 1 (дефолтному значению Шейп)
0
|
184 / 192 / 48
Регистрация: 25.08.2011
Сообщений: 792
|
|
22.10.2018, 22:05 | 16 |
0
|
0 / 0 / 0
Регистрация: 01.03.2016
Сообщений: 42
|
|
22.10.2018, 22:20 [ТС] | 17 |
я понял принцип сравнения так, что сравнивается параметр у двух объектов, и если А.а > B.b, то можно сортировать объекты так (по возрастанию параметра): B, A...
возможно не так понял... Добавлено через 7 минут а как надо в данном случае?
0
|
184 / 192 / 48
Регистрация: 25.08.2011
Сообщений: 792
|
|
22.10.2018, 23:03 | 18 |
надо просто:
return rA < rB
1
|
22.10.2018, 23:03 | |
22.10.2018, 23:03 | |
Помогаю со студенческими работами здесь
18
Сортировка списка с использованием std::sort Сортировка std::list с функцией sort() сортировка вектора sort() Сортировка массива структур по выбранному полю с помощью алгоритма std::sort Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |