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

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

Восстановить пароль Регистрация
Другие темы раздела
C++ Переделать код так, чтобы использовались диапазоны значений с помощью указателей http://www.cyberforum.ru/cpp-beginners/thread860064.html
Мне уже стыдно сюда писать ей богу :wall: . Но есть задача переделать Код№1 так чтобы использовались диапазоны значений с помощью указателей. А функция fill_array() должна возвращать следующий адрес после последнего введенного значения, и это значение должны принимать другие функции как количество элементов функций которые они должны обработать. Код№2 это что я пробовал, но там выводятся адреса...
C++ Программа для считывания содержимого директории (Си -> Си++) #include <stdio.h> #include <dirent.h> int main(int argc, char ** argv) { DIR * d; struct dirent * entry; if (argc != 2) { printf("Использование: %s <директория>\n", argv); return 0; http://www.cyberforum.ru/cpp-beginners/thread860063.html
Передвижение графических объектов на языке С++ C++
Здравствуйте. Помогите пожалуйста создать программу для решения задачи перемещения круга, вписанного в прямоугольник, по диагонали с заданным шагом и задержкой в полторы секунды... Программа должна содержать новые классы (включая абстрактные), конструкторы и деструкторы, поддерживать наследование, полиморфизм и видимость компонент. Буду очень благодарна за помощь.заранее спасибо огромное!)
C++ Определение количества символов в тексте
Во входном файле text.txt содержится текст на английском языке. Требуется написать программу, которая будет определять и выводить на экран английскую букву, встречающуюся в этом тексте чаще всего, и количество таких букв.Если искомых букв несколько, то программа должна вывести ту из них,которая идет раньше по алфавиту. Проблема в объявлении цикла проверки. ЧЯДНТ? #include "stdafx.h"...
C++ Подсчет букв "и" во введенной строке http://www.cyberforum.ru/cpp-beginners/thread860031.html
помогите составить программу.
C++ В С++ может ли argv быть двухмерным массивом? int main(int argc, char *argv) { argv = tolower(argv); argv = tolower(argv); Вот что это означает? Когда у argv с двумя аргументами? подробнее

Показать сообщение отдельно
relax95
1 / 1 / 0
Регистрация: 30.10.2012
Сообщений: 23
09.05.2013, 18:40  [ТС]     Посмотрите пожалуйста с "list"
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;
}
 
Текущее время: 18:00. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru