实验三、栈和队列的应用

实验三、栈和队列的应用

W1ndys Lv6

已完结

声明:仅供留档查阅,仅用作起到提示引导性作用,仅用作学习交流,切勿直接照搬

实验原理

  1. 顺序栈:顺序栈是一种基于数组实现的栈。它通过一个数组和一个栈顶指针实现。当有新元素入栈时,将新元素放在数组的末尾,并将栈顶指针向后移动一位。当需要出栈时,直接返回栈顶元素,并将栈顶指针向前移动一位。
  2. 链式栈:链式栈是一种基于链表实现的栈。它通过一个链表和一个头节点实现。当有新元素入栈时,将新元素插入到链表的头部,并更新头节点。当需要出栈时,直接返回头节点所指向的节点,并让头节点指向下一个节点。
  3. 循环队列:循环队列是一种特殊的队列,它在逻辑上是环形的。循环队列使用一个数组和两个指针(一个头指针和一个尾指针)来实现。当元素入队时,尾指针向前移动并添加新元素;当元素出队时,头指针向前移动。当尾指针到达数组的末尾时,它会从数组的开始继续。
  4. 链式队列:链式队列是基于单链表实现的队列。它使用一个单链表和两个指针(一个头指针和一个尾指针)来实现。当元素入队时,新元素被添加到链表的尾部,并更新尾指针;当元素出队时,头部的元素被移除,并更新头指针

实验内容和步骤

  1. 顺序栈
    • 入栈:将新元素放在数组的末尾,并将栈顶指针向后移动一位。
    • 出栈:返回栈顶元素,并将栈顶指针向前移动一位。
  2. 链式栈
    • 入栈:将新元素插入到链表的头部,并更新头节点。
    • 出栈:返回头节点所指向的节点,并让头节点指向下一个节点。
  3. 循环队列
    • 入队:尾指针向前移动并添加新元素。
    • 出队:头指针向前移动。当尾指针到达数组的末尾时,它会从数组的开始继续。
  4. 链式队列
    • 入队:新元素被添加到链表的尾部,并更新尾指针。
    • 出队:头部的元素被移除,并更新头指针。

代码主体

顺序栈SeqStack的实现:

自己写的

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
#include <iostream>
using namespace std;
const int StackSize = 100; // 定义最大栈顶具体情况具体分析

template<typename DataType> //定义模板类SeqStack
class SeqStack
{
public:
SeqStack(); //构造函数,初始化空栈
~SeqStack(); //析构函数
void Push(DataType x); //压栈
DataType Pop(); //出栈
DataType GetTop();//取栈顶
DataType TopTop();//取栈顶下标
int empty(); //判空操作
private:
DataType data[StackSize]; //存放栈元素的数组
int top; //栈顶元素的下标
};

template<typename DataType>
SeqStack<DataType>::~SeqStack()
{

}

template<typename DataType>
void SeqStack<DataType>::Push(DataType x)
{
if (top == StackSize -1 )
{
cout << "栈满" << endl;
}
else
{
top++;
data[top] = x;s
}

}

template<typename DataType>
DataType SeqStack<DataType>::Pop()
{
if (top == -1 )
{
cout << "栈空" << endl;
}
else
{
DataType x;
x = data[top];
top--;
return x;
}
}

template<typename DataType>
DataType SeqStack<DataType>::GetTop()
{
if (top == -1 )
{
cout << "栈空" << endl;
}
else
{
return data[top];
}

}

template<typename DataType>
int SeqStack<DataType>::empty()
{
if (top == -1)
{
return 1;
}
else
{
return 0;
}
}

template<typename DataType>
DataType SeqStack<DataType>::TopTop()
{
return top;
}

template<typename DataType>
SeqStack<DataType>::SeqStack()
{
top = -1;
}


int main()
{
int ws1 = 0;
SeqStack<int> S{};//定义顺序栈变量
S.Push(1);
S.Push(2);
S.Push(3);
cout << "系统已压栈1,2,3" << endl;
cout << "输入一个元素进行压栈" << endl;
cin >> ws1;
S.Push(ws1);
cout << "当前栈顶元素为:" << S.GetTop() << endl;
cout << "*****************" << endl;
cout << "执行一次出栈操作" << endl;
cout << "已释放" << S.Pop() << endl;
cout << "当前栈顶元素为:" << S.GetTop() << endl;
cout << "*****************" << endl;
cout << "执行一次判空操作" << endl;
if (S.empty() == 1)
{
cout << "栈空" << endl;
}
else
{
cout << "栈非空" << endl;
}
cout << "*****************" << endl;
cout << "正在出所有栈" << endl;
for (int i = S.TopTop(); i > -1 ; i--)
{
cout << "已释放" << S.Pop() << endl;
}
cout << "已释放出所有栈" << endl;
cout << "*****************" << endl;
cout << "执行一次判空操作" << endl;
if (S.empty() == 1)
{
cout << "栈空" << endl;
}
else
{
cout << "栈非空" << endl;
}
return 0;
}

链式栈LinkStack的实现:

自己写的

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
#include <iostream>
using namespace std;

template <typename DataType>
struct Node
{
DataType data;
Node<DataType>* next;
};

template <typename DataType>
class LinkStack
{
public:
LinkStack();
~LinkStack();
void Push(DataType x); //入栈
DataType Pop(); //出栈
DataType GetTop(); //取栈顶
int Empty(); //判空
private:
Node<DataType>* top;
};

template <typename DataType>
LinkStack<DataType>::LinkStack()
{
top = nullptr;
}

template <typename DataType>
LinkStack<DataType>::~LinkStack()
{
cout << "程序退出,析构函数被调用!" << endl;
while (!Empty())
{
cout << "出栈元素:" << Pop() << endl;
}
cout << "程序退出链栈已清空!" << endl;
}

template <typename DataType>
DataType LinkStack<DataType> ::GetTop()
{
if (top == nullptr)
cout << "下溢异常" << endl;
else
return top->data;
}


template <typename DataType>
void LinkStack<DataType> ::Push(DataType x)
{
Node<DataType>* s = nullptr;
s = new Node<DataType>;
s->data = x; //申请结点s数据域为x
s->next = top;
top = s; //将结点s插在栈顶
}

template <typename DataType>
DataType LinkStack<DataType> ::Pop()
{
Node<DataType>* p = nullptr;
DataType x;
if (top == nullptr)
{
cout << "栈空" << endl;
}
else
{
x = top->data; p = top; //暂存栈顶元素
top = top->next; //将栈顶结点摘链
delete p;
return x;
}
}

template <typename DataType>
int LinkStack<DataType>::Empty()
{
if (top == nullptr)
{
return 1;
}
else
{
return 0;
}

}

int main()
{
int ws1 = 0;
LinkStack<int> S{};//定义顺序栈变量S
S.Push(1);
S.Push(2);
S.Push(3);
cout << "系统已压栈1,2,3" << endl;
cout << "输入一个元素进行压栈" << endl;
cin >> ws1;
S.Push(ws1);
cout << "当前栈顶元素为:" << S.GetTop() << endl;
cout << "*****************" << endl;
cout << "执行一次出栈操作" << endl;
cout << "已释放" << S.Pop() << endl;
cout << "当前栈顶元素为:" << S.GetTop() << endl;
cout << "*****************" << endl;
cout << "执行一次判空操作" << endl;
if (S.Empty() == 1)
{
cout << "栈空" << endl;
}
else
{
cout << "栈非空" << endl;
}
cout << "*****************" << endl;
cout << "正在出所有栈" << endl;
while (S.Empty() != 1)
{
cout << "已释放" << S.Pop() << endl;
}
cout << "已释放出所有栈" << endl;
cout << "*****************" << endl;
cout << "执行一次判空操作" << endl;
if (S.Empty() == 1)
{
cout << "栈空" << endl;
}
else
{
cout << "栈非空" << endl;
}
return 0;
}

循环队列CirQueue的实现:

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
#include<iostream>
using namespace std;

const int QueueSize = 100; //最大长度
template <typename DataType>
class CirQueue
{
public:
CirQueue();
~CirQueue();
void EnQueue(DataType x);//入队
DataType DeQueue();//出队
DataType GetQueue();//取队头
int Empty();//判空操作
private:
DataType data[QueueSize];//存放需要的数组
int front, rear;//队头和队尾指针
};

template<typename DataType>
CirQueue<DataType>::CirQueue()
{
rear = front = QueueSize - 1;
}

template<typename DataType>
CirQueue<DataType>::~CirQueue()
{

}

template<typename DataType>
void CirQueue<DataType>::EnQueue(DataType x)
{
if ((rear+1)%QueueSize==front)
{
cout << "队满" << endl;
}
else
{
rear = (rear + 1) % QueueSize; //队尾指针+1
data[rear] = x; //在队尾插入元素
}
}

template<typename DataType>
DataType CirQueue<DataType>::DeQueue()
{
if ((rear + 1)%QueueSize==front )
{
cout << "队空" << endl;
}
else
{
front = (front + 1) % QueueSize;
return data[front];
}
}

template<typename DataType>
DataType CirQueue<DataType>::GetQueue()
{
if (front == rear)
{
cout << "队空" << endl;
}
else
{
return data[(front + 1) % QueueSize];
}

}

template<typename DataType>
int CirQueue<DataType>::Empty()
{
if (front == rear)
{
return 1;
}
else
{
return 0;
}
}

int main()
{
CirQueue<int> S{};
int x = 0;
S.EnQueue(1);
S.EnQueue(2);
S.EnQueue(3);
cout << "已入队1,2,3" << endl;
cout << "******取一次队头******" << endl;
cout << "队头是:" << S.GetQueue() << endl;
cout << "请输入一个元素进行入队" << endl;
cin >> x;
S.EnQueue(x);
cout << "已入队:" << x << endl;
cout << "******取一次队头******" << endl;
cout << "队头是:" << S.GetQueue() << endl;
cout << "******执行一次出队******" << endl;
cout << "已出队:" << S.DeQueue() << endl;
cout << "*****进行一次判空*****" << endl;
if (S.Empty() == 1)
{
cout << "队列空" << endl;
}
else
{
cout << "队列非空" << endl;
}
cout << "已出队:" << S.DeQueue() << endl;
cout << "已出队:" << S.DeQueue() << endl;
cout << "已出队:" << S.DeQueue() << endl;
cout << "*****进行一次判空*****" << endl;
if (S.Empty() == 1)
{
cout << "队列空" << endl;
}
else
{
cout << "队列非空" << endl;
}
return 0;
}

链式队列LinkQueue的实现:

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
#include<iostream>
using namespace std;

template<typename DataType>
struct node
{
DataType data;
node<DataType>* next;
};

template<typename DataType>
class LinkQueue
{
public:
LinkQueue();
~LinkQueue();
void enQueue(DataType x);
DataType DeQueue();
DataType GetQueue();
int Empty();
private:
node<DataType>* front, * rear;
};

template<typename DataType>
LinkQueue<DataType>::LinkQueue()
{
node<DataType>* s = nullptr;
s = new node<DataType>;//开辟空间
s->next = nullptr;
front = rear = s;

}

template<typename DataType>
LinkQueue<DataType>::~LinkQueue()
{
node<DataType>* q = nullptr;
while (front != nullptr)
{
q = front;
front = front->next;
delete q;
}
}

template<typename DataType>
void LinkQueue<DataType>::enQueue(DataType x)
{
node<DataType>* s = nullptr;
s = new node<DataType>;
s->data = x;
s->next = nullptr;
rear->next = s; //插入到队尾
rear = s; //移动队尾
}

template<typename DataType>
DataType LinkQueue<DataType>::DeQueue()
{
DataType x;
node<DataType>* p = nullptr;
if (reat==front )
{
cout << "队空" << endl;
}
else
{
p = front->next;
x = p->data;
front->next = p->next;
delete p;
return x;
}
}

template<typename DataType>
DataType LinkQueue<DataType>::GetQueue()
{
if (front == rear)
{
cout << "队空" << endl;
}
else
{
return front->next->data;
}
}

template<typename DataType>
int LinkQueue<DataType>::Empty()
{
if (front == rear )
{
return 1;
}
else
{
return 0;
}
}

int main()
{
int x;
LinkQueue<int> S = {};
S.enQueue(1);
S.enQueue(2);
S.enQueue(3);
cout << "已入队1,2,3" << endl;
cout << "******取一次队头******" << endl;
cout << "队头是:" << S.GetQueue() << endl;
cout << "请输入一个元素进行入队" << endl;
cin >> x;
S.enQueue(x);
cout << "已入队:" << x << endl;
cout << "******取一次队头******" << endl;
cout << "队头是:" << S.GetQueue() << endl;
cout << "******执行一次出队******" << endl;
cout << "已出队:" << S.DeQueue() << endl;
cout << "*****进行一次判空*****" << endl;
if (S.Empty() == 1)
{
cout << "队列空" << endl;
}
else
{
cout << "队列非空" << endl;
}
cout << "已出队:" << S.DeQueue() << endl;
cout << "已出队:" << S.DeQueue() << endl;
cout << "已出队:" << S.DeQueue() << endl;
cout << "*****进行一次判空*****" << endl;
if (S.Empty() == 1)
{
cout << "队列空" << endl;
}
else
{
cout << "队列非空" << endl;
}
return 0;
}

十进制转换为二至九进制之间的任一进制的算法实现:

这里有一个细节就是,任何数转化为任何进制,最后整除取整的结果都是0,而最后一次压栈是无法在循环里压栈(在这个算法里),需要在循环外再写一行压栈,把最后一个进制数压进去(也就是输出结果的第一位)

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
/*十进制转化为其他进制,实际上是做取余然后逆序输出运算,可以用顺序栈实现功能*/
#include <iostream>
using namespace std;
const int StackSize = 10000; // 定义最大栈顶具体情况具体分析

template<typename DataType> //定义模板类SeqStack
class SeqStack
{
public:
SeqStack(); //构造函数,初始化空栈
~SeqStack(); //析构函数
void Push(DataType x); //压栈
DataType Pop(); //出栈
DataType GetTop();//取栈顶
int empty(); //判空操作
private:
DataType data[StackSize]; //存放栈元素的数组
int top; //栈顶元素的下标
};

template<typename DataType>
SeqStack<DataType>::~SeqStack()
{

}

template<typename DataType>
void SeqStack<DataType>::Push(DataType x)
{
if (top == StackSize - 1)
{
cout << "栈满" << endl;
}
else
{
top++;
data[top] = x;
}

}

template<typename DataType>
DataType SeqStack<DataType>::Pop()
{
if (top == -1)
{
cout << "栈空" << endl;
}
else
{
DataType x;
x = data[top];
top--;
return x;
}
}

template<typename DataType>
DataType SeqStack<DataType>::GetTop()
{
if (top == -1)
{
cout << "栈空" << endl;
}
else
{
return data[top];
}

}

template<typename DataType>
int SeqStack<DataType>::empty()
{
if (top == -1)
{
return 1;
}
else
{
return 0;
}
}

template<typename DataType>
SeqStack<DataType>::SeqStack()
{
top = -1;
}

int main()
{
SeqStack<int> s = {};
int x, y, count = 1;
cout << "请按顺序输入你想转化的十进制数,和目标进制(2-9),以空格隔开" << endl;
cin >> x >> y;
while ((x/y) != 0)
{
cout <<"入栈" << x % y << endl;
s.Push(x % y);
count++;
x /= y;
}
s.Push(x % y);
cout << "入栈" << x % y << endl;
cout <<"************************" << endl;
cout << "转换后的结果是";
while (count!=0)
{
cout<<s.Pop();
count--;
}
cout << endl;
cout << "************************" << endl;
return 0;
}
  • 标题: 实验三、栈和队列的应用
  • 作者: W1ndys
  • 创建于 : 2023-10-05 21:07:00
  • 更新于 : 2025-01-11 18:09:36
  • 链接: https://blog.w1ndys.top/posts/a2945f82.html
  • 版权声明: 版权所有 © W1ndys,禁止转载。
评论