Форум программистов, компьютерный форум CyberForum.ru

Если память для объекта выделяется динамически (строка 33), сортировка sort не работает - C++

Восстановить пароль Регистрация
 
lotos580
1 / 1 / 1
Регистрация: 25.05.2012
Сообщений: 60
05.08.2014, 20:24     Если память для объекта выделяется динамически (строка 33), сортировка sort не работает #1
Если память для объекта выделяется динамически (строка 33), сортировка sort не работает, если память не выделять, все работает. Как избежать проблему?

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
#include <iostream>
#include <list>
#include <time.h>
using namespace std;
 
class Type
{
public:
    Type(int a) { x = a; }
    int getX() { return x; }
    bool operator < (const Type& obj2) { return x < obj2.x;  }
private:
    int x;
};
 
void print(list <Type*> list1)
{
    list<Type*>::iterator iter = list1.begin();
    while (iter != list1.end())
    {
        cout << (*iter)->getX() << ' ';
        iter++;
    }
    cout << endl;
}
 
int main()
{
    srand(time(0));
    list <Type*> list1;
    for (int i = 0; i < 10; i++)
    {
        list1.push_back(new Type(rand() % 1000));
    }
    print(list1);
    list1.sort();
    print(list1);
    return 0;
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
05.08.2014, 20:24     Если память для объекта выделяется динамически (строка 33), сортировка sort не работает
Посмотрите здесь:

C++ Как динамически выделить память для строкового массива?
Выделяется ли память для ссылки? C++
Не выделяется память C++
Какую структуру имеет память которая выделяется для роботы программы на С++ C++
Не работает сортировка Stl sort C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
CyberSolver
 Аватар для CyberSolver
101 / 74 / 17
Регистрация: 23.07.2014
Сообщений: 686
Записей в блоге: 1
05.08.2014, 20:26     Если память для объекта выделяется динамически (строка 33), сортировка sort не работает #2
lotos580, у вас в списке указатели. Как вы думаете, как они сортируются?

http://en.cppreference.com/w/cpp/algorithm/sort
Напишите свой компаратор тогда.
lotos580
1 / 1 / 1
Регистрация: 25.05.2012
Сообщений: 60
08.08.2014, 22:42  [ТС]     Если память для объекта выделяется динамически (строка 33), сортировка sort не работает #3
А если, допустим, я использую очередь с приоритетом с указателями на объекты класса, как мне написать функцию, которая сравнивает объекты в ней по ключам?
компилятор не допускает след. вариант функции:
C++
1
friend bool operator< (Type* obj1, Type* obj2);
Toshkarik
 Аватар для Toshkarik
1139 / 856 / 50
Регистрация: 03.08.2011
Сообщений: 2,381
Завершенные тесты: 1
09.08.2014, 00:08     Если память для объекта выделяется динамически (строка 33), сортировка sort не работает #4
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
#include <queue>
 
 
struct A {
   int a;
};
 
struct AComparator {
   bool operator()( const A *left, const A *right ) {
      return left->a < right->a;
   }
};
 
int main( int argc, const char *argv[] ) {
   ...
   std::priority_queue< A *, std::vector< A * >, AComparator > q;
   ...
}
Yandex
Объявления
09.08.2014, 00:08     Если память для объекта выделяется динамически (строка 33), сортировка sort не работает
Ответ Создать тему
Опции темы

Текущее время: 17:35. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru