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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
 
relax95
1 / 1 / 0
Регистрация: 30.10.2012
Сообщений: 23
#1

Посмотрите пожалуйста с "list" - C++

09.05.2013, 18:21. Просмотров 366. Ответов 16
Метки нет (Все метки)

У меня есть шаблонный список и - тип списка класс . Мне нужно реализовать поиск значения сравнивая с полями класса. Подскажите пожалуйста как можно обратится к одному полю класса.

Это как бы вывести все содержимое .
C++
1
2
3
4
5
6
for ( it = l.begin(); it != l.end(); it++ )
    {
        cout<<*it;
        
        
    }
Мне же надо вывести значения определенного поля .
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
09.05.2013, 18:21     Посмотрите пожалуйста с "list"
Посмотрите здесь:

Error C2039: list: не является членом "std" - C++
итак: делаю MFC проект. Собственные функции пишу в отдельном MyLibrary.cpp к которому еще прилагается MyLibrary.h. функция написана,...

Реализовать структуру "Список с пропусками" (Skip List) - C++
Доброго времени суток. Кто-нибудь сталкивался с написанием данной структуры ? Наткнулся у Страуструпа на задание,где необходимо реализовать...

Ошибка при компиляции: "List index out of bounds (0)" - C++
При компиляции выдается следующее сообщение. Среда:C++ Bulder 6 void __fastcall TForm1::FormCreate(TObject *Sender) { ...

Ошибка "List is not a template" - C++
Всем привет. Я только начала изучать библиотеку stl и тут же столкнулась с проблемой, когда контейнер объявлен в хедере какого-нибудь...

Напишите пожалуйста программу, которая "напрягает" видеокарту - C++
Просьба не стандартная, но смысл в ней такой - отказал у меня кулер на ноутбуке(после того как я его разбирал), хотел бы разобрать ноут, и...

Создать игру "Кто хочет стать миллионером" на языке С++ пожалуйста - C++
Создать игру &quot;Кто хочет стать миллионером&quot; на языке С++ пожалуйста

Проверьте, пожалуйста, код (выдает ошибку "Не удается найти указанный файл") - C++
/////////////////////////////////////////////////////////////////////////////// //В текстовом файле специальные термины выделены ...

После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Jupiter
Каратель
Эксперт С++
6553 / 3973 / 226
Регистрация: 26.03.2010
Сообщений: 9,273
Записей в блоге: 1
Завершенные тесты: 2
09.05.2013, 18:22     Посмотрите пожалуйста с "list" #2
it->field
relax95
1 / 1 / 0
Регистрация: 30.10.2012
Сообщений: 23
09.05.2013, 18:23  [ТС]     Посмотрите пожалуйста с "list" #3
не получается . пробывал перезагрузить оператор -> но тоже туго
Jupiter
Каратель
Эксперт С++
6553 / 3973 / 226
Регистрация: 26.03.2010
Сообщений: 9,273
Записей в блоге: 1
Завершенные тесты: 2
09.05.2013, 18:27     Посмотрите пожалуйста с "list" #4
что значит не получается? какие ошибки выдает компилятор?
relax95
1 / 1 / 0
Регистрация: 30.10.2012
Сообщений: 23
09.05.2013, 18:31  [ТС]     Посмотрите пожалуйста с "list" #5
ошибок компилятор не выдает :

просто я уверен что не так делаю :

Я думаю чтобы создать перегрузку нужно делать
C++
1
2
3
4
TYPE* operator -> () {
            
            return m_item->value();
        }
или же


C++
1
2
3
4
TYPE* operator -> () {
            TYPE *p = new TYPE;
            return p;
        }
но во втором случае мы попросту создаем новый объект, который не имеет отношения к первому
Jupiter
Каратель
Эксперт С++
6553 / 3973 / 226
Регистрация: 26.03.2010
Сообщений: 9,273
Записей в блоге: 1
Завершенные тесты: 2
09.05.2013, 18:33     Посмотрите пожалуйста с "list" #6
вам не нужна перегрузка оператора ->
просто напишите
C++
1
2
3
4
for (it = l.begin(); it != l.end(); ++it)
{
   cout << it->field;
}
bounce
4 / 4 / 2
Регистрация: 07.01.2013
Сообщений: 21
09.05.2013, 18:35     Посмотрите пожалуйста с "list" #7
а что именно туго?
relax95
1 / 1 / 0
Регистрация: 30.10.2012
Сообщений: 23
09.05.2013, 18:36  [ТС]     Посмотрите пожалуйста с "list" #8
тогда выдает компилятор :


error C2819: тип "List<TYPE>::Iterator" не имеет перегруженный "operator ->"
Jupiter
Каратель
Эксперт С++
6553 / 3973 / 226
Регистрация: 26.03.2010
Сообщений: 9,273
Записей в блоге: 1
Завершенные тесты: 2
09.05.2013, 18:37     Посмотрите пожалуйста с "list" #9

Не по теме:

и кто бы мог подумать что у вас свой итератор и свой список


дайте больше кода, нифига не ясно что у вас есть и что не получается
relax95
1 / 1 / 0
Регистрация: 30.10.2012
Сообщений: 23
09.05.2013, 18:40  [ТС]     Посмотрите пожалуйста с "list" #10
bounce, Туго в том, что оно не подсвечивает поля и методы класса. Как правильно перезагрузить оператор -> ?

Добавлено через 1 минуту
Jupiter, Да свой итератор и список . В STL я знаю как делать - там просто можно обратится

Добавлено через 1 минуту
Jupiter, Я скину реализацию списка
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
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
template< typename TYPE >
class List
{
private:
    class Item
    {
    private:
        friend class List;
        TYPE  m_data;
        Item *m_next;
        Item *m_prev;
 
    public:
        Item( const TYPE &v, Item *p, Item *n ) 
            : m_data( v ), m_next( n ), m_prev( p )
        {
            
            if( p ) p->m_next = this;
            if( n ) n->m_prev = this;
        }
        ~Item()
        {
            if( m_prev ) m_prev->m_next = m_next;
            if( m_next ) m_next->m_prev = m_prev;
        }
 
        Item* next( void ) { return m_next; }
        Item* prev( void ) { return m_prev; }
        TYPE& value( void ) { return m_data; }
        
 
    } *head, *tail;
 
public:
    class Iterator
    {
        friend class List;
    private:
        Item *m_item;
        Iterator( Item *it ) : m_item( it ) {}
    public:
        Iterator() : m_item( NULL ) {}
        Iterator( const Iterator *it ) : m_item( it->m_item ) {}
        ~Iterator() {}
 
        const Iterator& operator = ( const Iterator& it ) 
            { m_item = it.m_item; return *this; }
 
        bool operator == ( const Iterator& it ) 
            { return m_item == it.m_item; }
        bool operator != ( const Iterator& it ) 
            { return m_item != it.m_item; }
 
        Iterator& operator ++ ()
        {
            if( !m_item )
                throw std::runtime_error("Unexpected call");
            m_item = m_item->next();
            return *this;
        }
        Iterator& operator -- ()
        {
            if( !m_item )
                throw std::runtime_error("Unexpected call");
            m_item = m_item->prev();
            return *this;
        }
 
        TYPE& operator * () { return m_item->value(); };
    
    };
 
public:
    List( void ) : head( NULL ), tail( NULL ) {};
    List( const List &v ) { /* clear(); assign(); */ };
    ~List( void ) { clear(); };
 
    void clear( void )
    {
        for( Item *item = head; item; item = head )
        {
            head = item->next();
            delete item;
        }
        tail = head;
    }
 
    void push_back( const TYPE &v )
    {
        if( !head )
            head = tail = new Item( v, NULL, NULL );
        else
            tail = new Item( v, tail, NULL );
    }
    void pop_back()
    {
        if( !tail )
            throw std::runtime_error("List is empty !!!");
        Item *item = tail;
        tail = tail->prev();
        delete item;
    }
 
    void push_front( const TYPE &v )
    {
        if( !head )
            head = tail = new Item( v, NULL, NULL );
        else
            head = new Item( v, NULL, head );
    }
    void pop_front()
    {
        if( !head )
            throw std::runtime_error("List is empty !!!");
        Item *item = head;
        head = head->next();
        delete item;
    }
 
    void insert( Iterator &it, const TYPE &v )
    {
        if( head == NULL )
        {
            push_back( v );
        }
        else
        {
            if( it.m_item == NULL ) 
                throw std::invalid_argument("Invalid iterator");
            Item *item = new Item( v, it.m_item->prev(), it.m_item );
            if( head == it.m_item ) head = item;
        }
    }
    void erase( Iterator &it )
    {
        if( it.m_item == NULL )
            throw std::invalid_argument("Invalid iterator");
        if( head == NULL )
            throw std::runtime_error("List is empty");
        if( head == it.m_item ) head = it.m_item->next();
        if( tail == it.m_item ) tail = it.m_item->prev();
        delete it.m_item;
    }
 
    void assign( Iterator &it, const Iterator &b, const Iterator &e )
    {
        Iterator i;
        for( i = b; i != e; ++i, ++it )
            insert( it, *i );
    }
 
    Iterator begin() { return Iterator( head ); }
    Iterator end() { return Iterator(); }
 
    
};
 
 
 
 
class Info
{
public:
      int number;
      string fio;
      int year;
      string name;
      int kol;
      Info *next;
 
public:
 
    Info() { year = 0, name = ""; }
    Info( int num, string f, int yar, string nam, int kol ) : number(num), fio(f), year(yar), name(nam), kol(kol) {}
 
    int get_year()
    {
        return this -> year;
    }
 
    string get_name()
    {
        return this -> name;
    }
 
     int get_number()
    {
        return this -> number;
    }
 
    string get_fio()
    {
        return this -> fio;
    }
 
    int get_kol()
    {
        return this -> kol;
    }
 
    
    friend bool operator == ( const Info &p, const Info &t);
    friend bool operator == (  int p, const Info &t);
};
 
ostream &operator<<(ostream &stream, Info a){
    //stream<< "Number UDC " << "         " << "FIO  " << "       " << " Year " << "       " << " Name " << "      " << "Kol" <<endl;
    stream<<a.get_number()<<"            " <<a.get_fio()<< "       " <<a.get_year()<<"        " <<a.get_name()<< "        "<<a.get_kol();
return stream;
}
bounce
4 / 4 / 2
Регистрация: 07.01.2013
Сообщений: 21
09.05.2013, 18:41     Посмотрите пожалуйста с "list" #11
че т я опоздал
relax95
1 / 1 / 0
Регистрация: 30.10.2012
Сообщений: 23
09.05.2013, 18:42  [ТС]     Посмотрите пожалуйста с "list" #12
Jupiter,

А вот main()

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
List <Info> l;
    
    l.push_back(Info(19921,"Pavlenko D.O",1994,"Artyr",5));
 
    
 
    List <Info> ::Iterator it;
    cout<< "Number UDC " << "         " << "FIO  " << "       " << "  Year " << "       " << " Name " << "      " << "Kol" <<endl;
    for ( it = l.begin(); it != l.end(); it++ )
    {
        [COLOR="DarkRed"]cout<<it->number;[/COLOR]   нужно чтобы это действие выполнялось
        
        
        
    }
relax95
1 / 1 / 0
Регистрация: 30.10.2012
Сообщений: 23
09.05.2013, 18:44  [ТС]     Посмотрите пожалуйста с "list" #13
bounce,

Мне нужно чтобы в main() работало

C++
1
cout<<it->number;
Jupiter
Каратель
Эксперт С++
6553 / 3973 / 226
Регистрация: 26.03.2010
Сообщений: 9,273
Записей в блоге: 1
Завершенные тесты: 2
09.05.2013, 18:44     Посмотрите пожалуйста с "list" #14
Цитата Сообщение от relax95 Посмотреть сообщение
А вот main()
дайте класс итератора
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
09.05.2013, 18:47     Посмотрите пожалуйста с "list"
Еще ссылки по теме:

Задача "сумма цифр стоящих на четных позициях", исправьте пожалуйста ошибки - C++
Дано натуральное число n. Найти сумму цифр числа, находящихся на четных позициях (старшая цифра числа находится на первой позиции). ...

Помогите, пожалуйста, написать класс "Кадры" - C++
Вот есть задание &quot;Класс – КАДРЫ; Члены-данные (имя – char*;номер цеха – int;разряд – int).&quot; нужно сделать вот эти пункты: ...

Пожалуйста обьясните что вообще это такое "использование циклов с предпосылками и постпосылками" - C++
Пожалуйста обьясните что вообще это такое &quot;использование циклов с предпосылками и постпосылками&quot; ?

Посоветуйте пожалуйста литературу по С++ для начинающих,желательно с пометкой "для тупых" - C++
Нужна подробная литература по изучению С++,где было бы подробное объяснение каждого шага,наподобие книги &quot;Изучаем HTML,XHTML и CSS&quot;...

Расскажите пожалуйста про оператор "class" из учебника понял только как создать, как сделать содержимое открытым/закрытым... - C++
Расскажите пожалуйста про оператор &quot;class&quot; из учебника понял только как создать, как сделать содержимое открытым/закрытым... ...


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

Или воспользуйтесь поиском по форуму:
relax95
1 / 1 / 0
Регистрация: 30.10.2012
Сообщений: 23
09.05.2013, 18:47  [ТС]     Посмотрите пожалуйста с "list" #15
Jupiter,

вот Итератор

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
class Iterator
    {
        friend class List;
    private:
        Item *m_item;
        Iterator( Item *it ) : m_item( it ) {}
    public:
        Iterator() : m_item( NULL ) {}
        Iterator( const Iterator *it ) : m_item( it->m_item ) {}
        ~Iterator() {}
 
        const Iterator& operator = ( const Iterator& it ) 
            { m_item = it.m_item; return *this; }
 
        bool operator == ( const Iterator& it ) 
            { return m_item == it.m_item; }
        bool operator != ( const Iterator& it ) 
            { return m_item != it.m_item; }
 
        Iterator& operator ++ ()
        {
            if( !m_item )
                throw std::runtime_error("Unexpected call");
            m_item = m_item->next();
            return *this;
        }
        Iterator& operator -- ()
        {
            if( !m_item )
                throw std::runtime_error("Unexpected call");
            m_item = m_item->prev();
            return *this;
        }
 
        TYPE& operator * () { return m_item->value(); };
    };
Yandex
Объявления
09.05.2013, 18:47     Посмотрите пожалуйста с "list"
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru