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

Двусвязный список контейнеры и итераторы - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Работа с полями класса http://www.cyberforum.ru/cpp-beginners/thread1158945.html
class Account { public: float getBalance() { return Balance; } void setBalance(float& b) { Balance = b; } private: float Balance; }; int main() { Account a;
C++ Определитель матрицы, ранг матрицы, обратная матрица Вы можете помочь, сделать определитель матрицы, или у кого есть коде: ранг матрицы, обратная матрица, или другие действия с матрицами. http://www.cyberforum.ru/cpp-beginners/thread1158944.html
C++ Работа с векторами: названия цифр
Программа должна работать так вводишь число 2 она тебе выдает two; У меня почему-то ничего не происходит Вот код программы #include <iostream> #include <vector> using namespace std; inline void keep_window_open() { char ch; cin >> ch; } int main() { vector<string>numeres(10);
C++ Составить программу, которая печатает "столбиком" все вхождения в предложение некоторого символа
Дано предложение. Составить программу, которая печатает "столбиком" все вхождения в предложение некоторого символа.
C++ Программа с указателями. Из двух введенных множеств чисел составить третье множество http://www.cyberforum.ru/cpp-beginners/thread1158926.html
Из двух введенных множеств чисел составить третье множество, элементами которого будут совпадающие числа заданных множеств.
C++ Запись в файл 15 чисел в столбик Задача: Записать в файл 15 чисел из генератора случайных чисел. Запись в столбец. #include<iostream> #include<cstdlib> #include<ctime> #include <fstream> using namespace std; int main() { подробнее

Показать сообщение отдельно
Владислаучык
0 / 0 / 1
Регистрация: 21.03.2013
Сообщений: 323

Двусвязный список контейнеры и итераторы - C++

27.04.2014, 12:42. Просмотров 526. Ответов 5
Метки (Все метки)

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
#include <iostream>
#include <algorithm>
#include <list>
using namespace std;
 
 
class List
{
private:
    int info;
    List *prev, *next, *begin, *end, *t;
    //int t;
public:
    List();
    void f_add();
    void end_add();
    void add_key();
    void poisk();
    void del();
    void show();
};
 
void List::f_add()
{
    cout<<"Введите элемент который вы хотите добавить: ";
    List *t=new List;
    cin>>info;
    &t->info;
    t->prev=t->next;
    begin=end=t;
}
 
void List::end_add()
{
    
    //int t=0;
    List *t=new List;
    cin>>info;
    &t->info;
    t->next=NULL;
    t->prev=end;
    end->next=t;
    end=t;
}
 
void List::poisk()
{
    int ip=0;
    cin>>ip;
    List*key=NULL;
    t=begin; 
    while(t!=NULL)
    {
        if(t->info=ip)
        {
        key=t;
        break;
        }
        else
        t=t->next;
    }
    if(key=NULL)
    {
        cout<<"Не найдено";
    }
}
 
void List::show()
{
    t=begin; 
}
 
void List::del()
{
    int ip=0;
    cin>>ip;
    List*key=NULL;
    t=begin; 
    while(t!=NULL)
    {
        if(t->info=ip)
        {
        key=t;
        break;
        }
        else
        t=t->next;
    }
    if(key=NULL)
    {
        cout<<"Не найдено";
    }
    else 
        if(key==begin)
        {
            begin=begin->next;
            begin->prev=NULL;
        }
        if(key==end)
        {
            end=end->prev;
            end->next=NULL;
        }
        else
        {
            (key->prev)->next=key->next;
            (key->next)->prev=key->prev;
 
        }
        delete key; 
}
 
void List::add_key()
{
        int ip=0;
    cin>>ip;
    List*key=NULL;
    t=begin; 
    while(t!=NULL)
    {
        if(t->info=ip)
        {
        key=t;
        break;
        }
        else
        t=t->next;
    }
    if(key=NULL)
    {
        cout<<"Не найдено";
    }
    t=new List;
    cin>>info;
    &t->info;
    t->prev=key;
    t->next=key->next;
    key->next=t;
    if(key!=end)
    {
    (t->next)->prev=t;
    }
    else end=t;
}
 
int main()
{
    List obj;
    obj.f_add();
    obj.end_add();
    obj.end_add();
    obj.end_add();
    obj.add_key();
    obj.del();
}
error LNK2019: ссылка на неразрешенный внешний символ "public: __thiscall List::List(void)" (??0List@@QAE@XZ) в функции "public: void __thiscall List::add_key(void)" (?add_key@List@@QAEXXZ)
1>D:\в\лаба 5-6 по ооп\Debug\лаба 5-6 по ооп.exe : fatal error LNK1120: неразрешенных внешних элементов: 1

по заданию: Придумайте и реализуйте дважды связанный список, которым можно пользоваться посредством итератора. Итератор иметь действия для движения вперед и назад, действия для вставки и удаления элементов списка, и способ доступа к текущему элементу.
Вопрос: Как это всё сделать в виде контейнера, чтобы можно было пользоваться с помощью итератора?
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru