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

Очередь, конструктор копирования и перегруженный оператор присваивания - C++

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 9, средняя оценка - 5.00
Alex S
0 / 0 / 0
Регистрация: 18.11.2012
Сообщений: 5
28.11.2012, 13:23     Очередь, конструктор копирования и перегруженный оператор присваивания #1
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
#include <iostream>
using namespace std;
typedef char type;
 
struct Node
{
    type element;
    Node *pNext;
};
 
class Queue_elements
{
private:
    Node *Head;
    Node *Tail;
public:
    Queue_elements();
    ~Queue_elements();
    Queue_elements(Queue_elements &obj);
    void add_element(type x);
    void show();
    void delete_element();
    int size_queue();
};
 
Queue_elements::Queue_elements()
{
    Head = NULL;
    Tail = NULL;
}
 
Queue_elements::~Queue_elements()
{
    Node *temp = Head;
    while (temp!=NULL)
    {
        temp = Head -> pNext;
        delete Head;
        Head = temp;
    }
}
 
void Queue_elements::add_element(type x)
{
    Node *temp = new Node;
    temp -> element = x;
    temp -> pNext = NULL;
 
    if (Head!=NULL)
    {
        Tail -> pNext = temp;
        Tail = temp;
    }
    else
    {
        Head = temp;
        Tail = temp;
    }
}
 
void Queue_elements::show()
{
    Node *temp = Head;
    cout << "Текущая очередь элементов: ";
    while (temp != NULL)
    {
        cout << temp -> element <<" ";
        temp = temp -> pNext;
    }
    cout << endl;
}
 
void Queue_elements::delete_element()
{
    if (Head!=NULL)
    {
        Node *temp = Head;
        Head = Head  -> pNext;
        delete temp;
    }
}
 
int Queue_elements::size_queue()
{
    int i = 0;
    Node *temp = Head;
    if (temp != NULL)
    {
        while(temp!=NULL)
        {
            temp = temp -> pNext;
            i++;
        }
        return i;
    }
    else
        return 0;
}
 
 
int main()
{
    setlocale( LC_ALL, "Russian" );
    Queue_elements A;
    A.add_element('a');
    A.add_element('b');
    A.add_element('c');
    A.add_element('d');
    A.delete_element();
    A.show();
    //Queue_elements B = A;
    //B.show;
    system("pause");
    return 0;
}
В общем реализовал класс "очередь элементов", но пока не получается дописать конструктор копирования и перегруженный оператор присваивания, если кто может помогите плз.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
28.11.2012, 13:23     Очередь, конструктор копирования и перегруженный оператор присваивания
Посмотрите здесь:

C++ Конструктор присваивания или копирования
Конструктор копирования и оператор присваивания C++
C++ Про конструктор копирования, оператор присваивания
Перегруженный оператор присваивания C++
C++ Ребят, уже запарился, гляньте, что не так!? конструктор копирования и оператор присваивания
Конструктор копирования, присваивания C++
Перегруженный оператор присваивания C++
C++ Не выполняется перегруженный оператор присваивания

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
vxg
Модератор
 Аватар для vxg
2658 / 1669 / 156
Регистрация: 13.01.2012
Сообщений: 6,214
28.11.2012, 15:12     Очередь, конструктор копирования и перегруженный оператор присваивания #2
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
Queue_elements::Queue_elements(const Queue_elements &obj)
{
        Node *temp = obj.Head;
        while (temp)
        {
            add_element(temp->element);
            temp = temp->Next;
        }
}
 
const Queue_elements &Queue_elements::operator=(const Queue_elements &obj)
{
    if (this != &obj)
    {
        Node *temp = Head;
        while (temp)
        {
            Head = Head->pNext;
            delete temp;
            temp = Head;
        }
 
        temp = obj.Head;
        while (temp)
        {
            add_element(temp->element);
            temp = temp->Next;
        }
    }
 
    return *this;
}
Yandex
Объявления
28.11.2012, 15:12     Очередь, конструктор копирования и перегруженный оператор присваивания
Ответ Создать тему
Опции темы

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