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

Очередь? What - C++

Восстановить пароль Регистрация
 
Anastasiya1
0 / 0 / 0
Регистрация: 21.03.2013
Сообщений: 77
21.03.2013, 17:48     Очередь? What #1
Всем доброго время суток.Дело в том, что с трудом дается с++, но очень хочется стать программистом.Вообщем ничего толком не объяснив препод дал нам задание и сказал реализовать очередь(ф-ии isEmpty,put и get) написав вот такую программку...
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
#include <iostream>
 
using namespace std;
 
struct tTreeElement
{
   int info;
   tTreeElement*l,*r;
}
 struct tQueueElem
 {
     tTreeElement*value;
     tQueueElem*next;
 }TQUEUE q;
 q.head;q.tail;q.tail->next=new tQueueElem;
struct TQUEUE
{
    tQueueElem*head,*value;
}
 
 
void main()
{
    int max;
    tTreeElement*root;
    max=root->info;
    tQueue q;
    put(q,root);
    while(!isEmpty(q))
    {
        tTreeElement*temp=get(q);
        if(temp->info>max)
        max=temp->info;
    }
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
yoghurt92
373 / 344 / 22
Регистрация: 17.05.2012
Сообщений: 1,049
21.03.2013, 18:13     Очередь? What #2
Anastasiya1, так что у вас конкретно не получается? очередь - частный случай связанного списка, который реализует политику FIFO(первый пришел, первый вышел)
Anastasiya1
0 / 0 / 0
Регистрация: 21.03.2013
Сообщений: 77
21.03.2013, 18:19  [ТС]     Очередь? What #3
Я не знаю как сделать ф-ии, я толко не понимаю эту программу, можете помочь в преобразовании нехватающих ф-ий...
yoghurt92
373 / 344 / 22
Регистрация: 17.05.2012
Сообщений: 1,049
21.03.2013, 18:21     Очередь? What #4
Anastasiya1, вот вам готовая очередь, если что-то не поймете, обращайтесь

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
#include "stdafx.h"
#include <iostream>
#include <locale>                       //для работы с юникодом
using namespace std;
 
struct Queue
{
    int data;
    Queue *next;
};
 
class QueueNode
{
    private:
        Queue *Head;
 
    public:
        QueueNode()
        {
            Head = NULL;
        }
 
        void addToFront(const int value)    //добавляем в начало            
        {
            Queue *Ptr = new Queue;
            Ptr -> data = value;
 
            Ptr -> next = Head;
            Head = Ptr;
        }
 
        void delQueue()                     //удаляем из начала
        {
            Queue *tmp = Head;
            Queue *cur = NULL;
 
            if(Head != NULL)
            {
                cur = Head -> next;
                delete Head;
                Head = cur;
            }
        }
 
        void showQueue()                    //вывод очереди
        {
            Queue *temp = Head;
 
            if(Head != NULL)
            {
                while(temp != NULL)
                {
                    cout << temp -> data << " ";
                    temp = temp -> next;
                }
            }
            else
                wcout << L"Очередь пуста!";
        }
 
};
 
void instructions();
void menu();
 
int _tmain(int argc, _TCHAR* argv[])
{
    wcout.imbue(locale(".866"));
    wcin.imbue(locale(".866"));
 
    menu();
 
    cout << "\n\n";
    return 0;
}
 
void instructions()
{
    wcout << L"Выберите пункт меню: " <<
        L"\n1 - Добавить элемент" <<
        L"\n2 - Удалить элемент" <<
        L"\n3 - Выход.\n";
}
 
void menu()
{
    QueueNode Universal;
    int punkt_menu, value;
 
    instructions();
 
    do{
        wcout << L"\n? ";
            cin >> punkt_menu;
 
            switch(punkt_menu)
            {
                case 1:
                    wcout << L"Введите число: ";
                        cin >> value;
 
                    Universal.addToFront(value);
                    Universal.showQueue();
                    break;
                case 2:
                    Universal.delQueue();
                    Universal.showQueue();
                    break;
            }
 
    }while(punkt_menu != 3);
}
Anastasiya1
0 / 0 / 0
Регистрация: 21.03.2013
Сообщений: 77
21.03.2013, 18:24  [ТС]     Очередь? What #5
в нее нужно добавить ф-ии [bool isEmpty(tQueue queue)]; put(tQueue queue, tTreeElement*te) и tTreeElement(tQueue queue).Я не знаю как это сделать(

Добавлено через 20 секунд
в ту программу которую описала выше....
yoghurt92
373 / 344 / 22
Регистрация: 17.05.2012
Сообщений: 1,049
21.03.2013, 18:26     Очередь? What #6
Anastasiya1, а вы компилировали программу? сдается мне, она не рабочая...
Anastasiya1
0 / 0 / 0
Регистрация: 21.03.2013
Сообщений: 77
21.03.2013, 18:28  [ТС]     Очередь? What #7
Ну в ней 3-х функций не хватает....Вот это мне и нужно(эти три ф-ии и всеее
yoghurt92
373 / 344 / 22
Регистрация: 17.05.2012
Сообщений: 1,049
21.03.2013, 18:30     Очередь? What #8
Anastasiya1, ваша программа не рабочая, я не пойму вообще что нужно, напишите задание...
rangerx
1908 / 1517 / 139
Регистрация: 31.05.2009
Сообщений: 2,876
21.03.2013, 18:34     Очередь? What #9
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
#include <iostream>
 
struct Node
{
    int data;
    Node* next;
};
 
struct Queue
{
    Node* head;
    Node* tail;
};
 
void queueInit(Queue& q)
{
    q.head = q.tail = NULL;
}
 
void queuePush(Queue& queue, int data)
{
    Node* newNode = new Node();
    newNode->data = data;
    newNode->next = NULL;
 
    if(queue.head == NULL)
    {
        queue.head = newNode;
        queue.tail = queue.head;
    }
 
    else
    {
        queue.tail->next = newNode;
        queue.tail = queue.tail->next;
    }
}
 
void queuePop(Queue& q)
{
    Node* nextNode = q.head->next;
    delete q.head;
    q.head = nextNode;
}
 
bool queueEmpty(const Queue& queue)
{
    return queue.head == NULL;
}
 
int main()
{
    Queue queue;
    queueInit(queue);
 
    for(int i = 0; i < 10; ++i)
        queuePush(queue, i);
 
    while(!queueEmpty(queue))
    {
        std::cout << queue.head->data << '\n';
        queuePop(queue);
    }
}
Anastasiya1
0 / 0 / 0
Регистрация: 21.03.2013
Сообщений: 77
21.03.2013, 18:36  [ТС]     Очередь? What #10
Найти макс в дереве(обход в ширину) используя очередь...Наш препод написал эту программу, сказав что мы должны найти ф-ии-bool isEmpty(tQueue queue); put(tQueue queue, tTreeElement*te) и tTreeElement(tQueue queue) тоесть закончить начатую программу этими ф-иями.
yoghurt92
373 / 344 / 22
Регистрация: 17.05.2012
Сообщений: 1,049
21.03.2013, 18:39     Очередь? What #11
Anastasiya1, так вы сначала сформулируйте задание, а то очередь...

Добавлено через 1 минуту
Anastasiya1, найти нужно максимальное значение в дереве?
Anastasiya1
0 / 0 / 0
Регистрация: 21.03.2013
Сообщений: 77
21.03.2013, 18:50  [ТС]     Очередь? What #12
Найти макс в дереве(обход в ширину) используя очередь...Наш препод написал эту программу, сказав что мы должны найти ф-ии-bool isEmpty(tQueue queue); put(tQueue queue, tTreeElement*te) и tTreeElement(tQueue queue) тоесть закончить начатую программу этими ф-иями.
yoghurt92
373 / 344 / 22
Регистрация: 17.05.2012
Сообщений: 1,049
21.03.2013, 18:50     Очередь? What #13
Anastasiya1, вот вам дерево и очередь к нему

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
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
// obr.cpp : Defines the entry point for the console application.
//
 
#include "stdafx.h"
#include <iostream>
#include <iomanip>
#include <locale>
using namespace std;
 
struct Tree
{
    int data;
    Tree *left,
         *right;
};
 
struct Queue
{
    Tree *trans;
    Queue *next;
};
 
class QueueNode
{
    private:
        Queue *Head;
 
    public:
        QueueNode()
        {
            Head = NULL;
        }
 
        int isEmpty()
        {
            if(Head == NULL)
                return 1;
            else 
                return 0;
        }
 
        void addToQueue(Tree *tmp)
        { 
            Queue *Ptr = new Queue;
            Ptr -> trans = tmp;
 
            if(Head == NULL)
            {
                Head = Ptr;
                Ptr -> next = NULL; 
            }
            else
            {
                Queue *tmp_c = Head;
 
                while(tmp_c -> next != NULL)
                    tmp_c = tmp_c -> next;
 
                tmp_c -> next = Ptr;
                Ptr -> next = NULL; 
            }
        }
 
        Tree *delQueue()
        {
            Queue *cur = Head -> next;
            Tree *tmp_c = Head -> trans;
 
            if(Head != NULL)
            {
                delete Head;
                Head = cur;
                return tmp_c;
            }
            else
                return NULL;
        }
};
 
class TreeNode
{
    private:
        Tree *root,
             *next;
 
    public:
        TreeNode()
        {
            root = NULL;
        }
 
        void levelOrder()
        {
            QueueNode Universal;
            Universal.addToQueue(root);
 
            Tree *tmp;
 
            while(!Universal.isEmpty())
            {
                tmp = Universal.delQueue();
                cout << tmp -> data << " ";
 
                if(tmp -> left != NULL)
                    Universal.addToQueue(tmp -> left);
                if(tmp -> right != NULL)
                    Universal.addToQueue(tmp -> right);
            }
        }
 
        void addToTreeHelper(int const value)
        {
            addToTree(&root, value);
        }
 
        void addToTree(Tree **Ptr, int const value)
        {
            if((*Ptr )== NULL)
            {
                (*Ptr) = new Tree;
                (*Ptr) -> data = value;
                (*Ptr) -> left = (*Ptr) -> right = NULL;
            }
            else
            {
                if(value < (*Ptr) -> data)
                    addToTree(&(*Ptr) -> left, value);
                else if(value > (*Ptr) -> data)
                    addToTree(&(*Ptr) -> right, value);
                else 
                    wcout << L"Дубликат!\n";
            }
        }
 
        void showTreeHelper()
        {
            if(root == NULL)
                wcout << L"Дереов пустое!\n";
            else
                showTree(root);
        }
 
        void showTree(Tree *Ptr)
        {
            if(Ptr != NULL)         //обход дерева в ширину
            {
                wcout << Ptr -> data << " ";
                showTree(Ptr -> left);
                showTree(Ptr -> right);
            }
        }
 
        void deleteTreeHelp(int const value)
        {
            deleteTree(root, value);
        }
 
        void deleteTree(Tree *Ptr, int const value)
        {
            Tree *parent = NULL;
            Tree *removed = NULL;
 
            while(Ptr != NULL && Ptr -> data != value)
            {
                parent = Ptr;
                if(Ptr -> data > value)
                    Ptr = Ptr -> left;
                else
                    Ptr = Ptr -> right;
            }
 
            int peremen = Ptr -> data;
 
            if(Ptr != NULL)
            {
                Tree *child = NULL;
                if(Ptr -> left == NULL || Ptr -> right == NULL)
                {
                    /*случай когда один ребенок*/
                    if(Ptr -> left == NULL)
                        child = Ptr -> right;
                    else
                        child = Ptr -> left;
 
                    /*усли удаляем корень с одним потомком*/
                    if(Ptr -> data == root -> data)
                        root = child;
                    else
                    {
                        if(parent -> left == Ptr)
                            parent -> left = child;
                        else
                            parent -> right = child;
                    }
 
                    removed = Ptr;
 
                }
                else            /*if(Ptr -> left != NULL || Ptr -> right != NULL)*/
                {
                    /*случай когда 2 ребенка*/
                    Tree *mostLeft = Ptr -> right;
                    Tree *temp = NULL;
 
                    while(mostLeft -> left != NULL)
                    {
                        temp = mostLeft;
                        mostLeft = mostLeft -> left;
                    }
 
                    Tree *child1, *child2;
                    child1 = child2 = NULL;
 
                    child1 = Ptr -> left;
                    child2 = Ptr -> right;
 
                    if(parent -> left == Ptr)
                        parent -> left = mostLeft;
                    else
                        parent -> right = mostLeft;
 
                    mostLeft ->left = child1;
                    mostLeft ->right = child2;
 
                    if(temp -> left == mostLeft)
                        temp -> left = NULL;
                    else
                        temp -> right = NULL;
 
                    removed = Ptr;
                }
            }
 
            wcout << removed -> data << L" удалено!\n";
            delete removed;
        }
 
        bool isEmpty()
        {
            return root == NULL ? true : false;
        }
 
        void outputHelper(int totalSpace)
        {
            outputTree(root, totalSpace);
        }
 
        void outputTree(Tree *Ptr, int totalSpace)
        {
            while(Ptr != NULL)
            {
                outputTree(Ptr -> right, totalSpace + 5);
 
                for(int i = 1; i <= totalSpace; i++)
                    cout << " ";
 
                cout << Ptr -> data << "\n";
 
                Ptr = Ptr -> left;
                totalSpace += 5;
            }
        }
};
 
void instructions();
void menu();
 
int _tmain(int argc, _TCHAR* argv[])
{
    wcout.imbue(locale(".866"));
    wcin.imbue(locale(".866"));
 
    menu();
 
    cout << "\n\n";
    return 0;
}
 
void instructions()
{
    wcout << L"Выберите пункт меню: " <<
        L"\n1 - Добавить элемент" <<
        L"\n2 - Удалить элемент" <<
        L"\n3 - Послойный обход дерева" <<
        L"\n4 - Проверка на пустоту" <<
        L"\n5 - Вывод дерева" <<
        L"\n6 - Выход.\n";
}
 
void menu()
{
    TreeNode Universal;
    int punkt_menu, value, space = 0;
 
    instructions();
 
 
    do{
        wcout << L"\n? ";
            cin >> punkt_menu;
 
            switch(punkt_menu)
            {
                case 1:
                    wcout << L"Введите число: ";
                        cin >> value;
 
                    Universal.addToTreeHelper(value);
                    Universal.showTreeHelper();
                    break;
                case 2:
                    wcout << L"Введите значение удаляемого элемента: ";
                        cin >> value;
 
                    Universal.deleteTreeHelp(value);
                    Universal.showTreeHelper();
                case 3:
                    Universal.levelOrder();
                    break;
                case 4:
                    if(Universal.isEmpty())
                        wcout << L"Дерево пустое!";
                    else
                        wcout << L"Дерево не пустое!";
                    break;
                case 5:
                    wcout << L"Вывод дерева:\n\n";
                    Universal.outputHelper(space);
                    break;
            }
 
    }while(punkt_menu != 5);
}
Anastasiya1
0 / 0 / 0
Регистрация: 21.03.2013
Сообщений: 77
21.03.2013, 19:29  [ТС]     Очередь? What #14
Найти макс в дереве(обход в ширину) используя очередь...Наш препод написал эту программу, сказав что мы должны найти ф-ии-bool isEmpty(tQueue queue); put(tQueue queue, tTreeElement*te) и tTreeElement(tQueue queue) тоесть закончить начатую программу этими ф-иями.
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
21.03.2013, 19:32     Очередь? What
Еще ссылки по теме:

Создать очередь. Добавить элемент в очередь. Удалить элемент из очереди C++
Очередь, теория. Очередь на шести стеках C++

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

Или воспользуйтесь поиском по форуму:
yoghurt92
373 / 344 / 22
Регистрация: 17.05.2012
Сообщений: 1,049
21.03.2013, 19:32     Очередь? What #15
Anastasiya1, по мне, так там написан бред, да еще и с ошибками... да и зачем там 3 структуры? 1 для дерева, другая для очереди, зачем еще одна?
Yandex
Объявления
21.03.2013, 19:32     Очередь? What
Ответ Создать тему
Опции темы

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