首页 > 其他 > 详细

数据结构——链栈及其操作

时间:2018-05-22 17:47:15      阅读:175      评论:0      收藏:0      [点我收藏+]
 1 #include<iostream>
 2 using namespace std;
 3 
 4 typedef int Status;
 5 typedef int ElemType;
 6 #define OK 1
 7 #define ERROR 0
 8 
 9 
10 //链栈的存储结构
11 typedef struct StackNode
12 {
13     ElemType data;                //数据域
14     struct StackNode *next;        //指针域
15 }StackNode,*LinkStack;
16 
17 
18 //初始化,构造一个空栈
19 Status InitStack(LinkStack &S)
20 {
21     S = NULL;
22     return OK;
23 }
24 
25 
26 //入栈
27 //在栈顶插入元素e
28 Status Push(LinkStack &S, ElemType e)
29 {
30     LinkStack p;            //生成新结点
31     p = new StackNode;        
32     p->data = e;
33     p->next = S;            //将新结点插入栈顶
34     S = p;                    //修改栈顶指针为p
35     return OK;
36 }
37 
38 
39 //出栈
40 //删除S的栈顶元素,用e返回其值
41 Status Pop(LinkStack &S, ElemType &e)
42 {
43     LinkStack p;
44     
45     if (S == NULL)        //栈空
46         return ERROR;
47 
48     e = S->data;    //将栈顶元素赋值给e
49     p = S;            //用p临时保存栈顶元素空间,以备释放
50     S = S->next;    //修改栈顶指针
51     delete p;        //释放原栈顶元素的空间
52     return OK;
53 }
54 
55 
56 //取栈顶元素
57 ElemType GetTop(LinkStack S)
58 {
59     if (S != NULL)    //栈非空
60         return S->data;        //返回栈顶元素的值,栈顶指针不变
61     else
62         return ERROR;
63 }
64 
65 
66 int main()
67 {
68     int n, x;
69     LinkStack S;
70 
71     InitStack(S);
72 
73     cout << "请输入链栈的元素个数:" << endl;
74     cin >> n;
75 
76     cout << "请依次输入" << n << "个元素:" << endl;
77 
78     while (n--)
79     {
80         cin >> x;
81         Push(S, x);
82     }
83 
84     cout << "元素依次出栈:" << endl;
85     while (S != NULL)
86     {
87         cout << GetTop(S) << " ";
88         Pop(S, x);
89     }
90 
91     system("pause");
92     return 0;
93 }

 

数据结构——链栈及其操作

原文:https://www.cnblogs.com/friend-A/p/9073097.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!