-
Notifications
You must be signed in to change notification settings - Fork 1
/
lstack.cpp
115 lines (93 loc) · 2.47 KB
/
lstack.cpp
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
/*
* lstack.cpp
*
* Created on: 16.03.2017 г.
* Author: trifon
*/
#include <iostream>
#include "lstack.h"
LinkedStack::LinkedStack() : top(nullptr) {}
bool LinkedStack::empty() const {
return top == nullptr;
}
void LinkedStack::push(int x) {
StackElement* p = new StackElement;
p->data = x;
p->next = top;
top = p;
}
int LinkedStack::pop() {
if (empty()) {
// Стекът е празен
std::cerr << "Опит за изключване на елемент от празен стек!\n";
return 0;
}
StackElement* p = top;
top = top->next;
int x = p->data;
delete p;
return x;
}
int LinkedStack::peek() const {
if (empty()) {
// Стекът е празен
std::cerr << "Опит за достъп до върха на празен стек!\n";
return 0;
}
return top->data;
}
LinkedStack::~LinkedStack() {
// !!! delete top;
// !!! delete[] top;
while (!empty())
pop();
}
/*
LinkedStack::LinkedStack(LinkedStack const& ls) :
top(nullptr) {
// ако ls е празен, няма какво да правим повече
if (ls.empty())
return;
// сигурни сме, че в ls има поне един елемент
// копираме първия елемент
StackElement* lastCopied = new StackElement;
lastCopied->data = ls.top->data;
// първият копиран елемент е върхът на стека
top = lastCopied;
// копираме останалите от втория елемент нататък
for(StackElement* toCopy = ls.top->next;
toCopy != nullptr;
toCopy = toCopy -> next) {
// правим копие на клетката, която сочи toCopy
StackElement* copied = new StackElement;
copied->data = toCopy->data;
lastCopied->next = copied;
lastCopied = copied;
}
// Последният елемент няма следващ
lastCopied->next = nullptr;
}
*/
void LinkedStack::copy(StackElement* toCopy) {
if (toCopy == nullptr)
return;
// сигурен съм, че има поне един елемент
// Копирам стека от втория елемент нататък
copy(toCopy->next);
// добавям и първия елемент отгоре
push(toCopy->data);
}
LinkedStack::LinkedStack(LinkedStack const& ls) :
top(nullptr) {
copy(ls.top);
}
/*
LinkedStack::LinkedStack(LinkedStack const& ls) :
top(nullptr) {
for(StackElement* toCopy = ls.top;
toCopy != nullptr;
toCopy = toCopy -> next) {
push(toCopy->data);
}
}
*/