-
Notifications
You must be signed in to change notification settings - Fork 4
Expand file tree
/
Copy path2-1stack.cpp
More file actions
128 lines (120 loc) · 2 KB
/
2-1stack.cpp
File metadata and controls
128 lines (120 loc) · 2 KB
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
/*
第二周 第一题
1)创建顺序栈;
2)插入操作:向栈顶压入值为 x 的元素;
3)删除操作:弹出栈顶元素;
4)存取操作:读取栈顶元素。
*/
#include <iostream>
#include <vector>
#include <string>
using namespace std;
#define MAX_SIZE 200 //定义最大栈长度
template<typename T>
class Stack
{
T data[MAX_SIZE];
int last;
public:
Stack(){last=-1;}
int push(T);
int pop();
vector<T> read();
int size();
bool empty();
bool full();
int show();
};
template<typename T>
int Stack<T>::push(T dat)
{
if(full())
return 1; //当前栈已满,pop或者增加栈容量重试
last++;
data[last]=dat;
return 0;
}
template<typename T>
int Stack<T>::pop()
{
if(empty())
return 1; //空栈无法执行退栈操作
last--;
return 0;
}
template<typename T>
vector<T> Stack<T>::read()
{
vector<T>v;
if(empty())
return v; //空栈无法执行取栈顶操作
v.push_back(data[last]);
return v;
}
template<typename T>
int Stack<T>::size()
{
return last+1;
}
template<typename T>
bool Stack<T>::empty()
{
if(last==-1)
return true;
return false;
}
template<typename T>
bool Stack<T>::full()
{
if(last==MAX_SIZE)
return true;
return false;
}
template<typename T>
int Stack<T>::show()
{
if(empty())
{
cout<<"当前为空栈"<<endl;
return 0;
}
for(int i=0;i<=last;i++)
cout<<data[i]<<" ";
cout<<endl;
return 0;
}
int main()
{
class Stack<char> s;
int ret=0;
string cmd;
while(cin>>cmd)
{
if(cmd=="push")
{
char dat;
cin>>dat;
ret=s.push(dat);
if(ret==1)
cout<<"当前栈已满,pop或者增加栈容量重试"<<endl;
}
if(cmd=="pop")
{
ret=s.pop();
if(ret==1)
cout<<"空栈无法执行退栈操作"<<endl;
}
if(cmd=="read")
{
cout<<" ";
vector<char>v=s.read();
if(v.empty())
cout<<endl<<"空栈无法执行取栈顶操作";
else
cout<<v[0];
cout<<endl;
}
s.show();
}
return 0;
}