数据结构(C语言版)实现链栈的创建,赋值随机数,进栈,出栈,取栈顶元素,输出

简介: 数据结构(C语言版)实现链栈的创建,赋值随机数,进栈,出栈,取栈顶元素,输出

数据结构(C语言版)实现链栈的创建,赋值随机数,进栈,出栈,取栈顶元素,输出

1.链表(链式存储结构):

运算时受限的单链表,只能在链表头部进行操作,故没有必要附加头结点,栈顶指针就是链表的头指针

2.图示

image.png

3.代码块

  • 链栈定义
//链栈定义 typedefstructStackNode{
SElemTypedata;
structStackNode*next;
}StackNode,*LinkStack; 
  • 链栈初始化
//链栈初始化StatusInitStack(LinkStack&S){
S=NULL;
returnOK;
} 
  • 链栈压栈
//链栈进栈StatusPush(LinkStack&S,SElemTypee){
//创建新结点,链栈没有上限 StackNode*p=newStackNode();
if(!p) returnERROR;
p->data=e;
p->next=S;
S=p;
returnOK;
}
  • 链栈出栈
//链栈出栈StatusPop(LinkStack&S,SElemType&e){
//判断链栈是不是空if(!S) returnERROR;
StackNode*p=S;
e=S->data;
S=S->next;
deletep;
returnOK;
} 
  • 链栈获取栈顶元素
//取链栈栈顶元素 StatusGetTop(LinkStackS,SElemType&e){
//判断链栈是不是空if(!S) returnERROR;
e=S->data;
returnOK; 
} 
  • 链栈赋随机值
//链表赋值 StatusInStack(LinkStack&S,intn){
for(inti=0;i<n;i++){
Push(S,rand());
    }
returnOK;
}
  • 链栈输出
//链栈打印StatusPrintStack(LinkStackS){
//判断链栈是不是空 if(!S) returnERROR;
for(inti=0;S;i++){
cout<<S->data<<" ";
S=S->next;
    }
cout<<endl;
returnOK;
} 

4.代码实现

#include<iostream>#include<stdlib.h>usingnamespacestd;
#define ERROR 0#define OK 1typedefintSElemType;
typedefintStatus;
//链栈定义 typedefstructStackNode{
SElemTypedata;
structStackNode*next;
}StackNode,*LinkStack; 
//链栈初始化StatusInitStack(LinkStack&S){
S=NULL;
returnOK;
} 
//链栈进栈StatusPush(LinkStack&S,SElemTypee){
//创建新结点,链栈没有上限 StackNode*p=newStackNode();
if(!p) returnERROR;
p->data=e;
p->next=S;
S=p;
returnOK;
} 
//链栈出栈StatusPop(LinkStack&S,SElemType&e){
//判断链栈是不是空if(!S) returnERROR;
StackNode*p=S;
e=S->data;
S=S->next;
deletep;
returnOK;
} 
//取链栈栈顶元素 StatusGetTop(LinkStackS,SElemType&e){
//判断链栈是不是空if(!S) returnERROR;
e=S->data;
returnOK; 
} 
//链栈打印StatusPrintStack(LinkStackS){
//判断链栈是不是空 if(!S) returnERROR;
for(inti=0;S;i++){
cout<<S->data<<" ";
S=S->next;
    }
cout<<endl;
returnOK;
} 
//链表赋值 StatusInStack(LinkStack&S,intn){
for(inti=0;i<n;i++){
Push(S,rand());
    }
returnOK;
}
intmain(){
inte;
//链表初始化 LinkStackS;
InitStack(S);
//链表赋值 cout<<"链表赋值"<<endl; 
cout<<"随机给链表赋值多少个"<<endl; 
cin>>e; 
InStack(S,e);
//遍历输出链表 cout<<"链表赋值完成:"<<endl; 
PrintStack(S);
//链表进栈 cout<<"链表进栈"<<endl;
cout<<"要进栈的元素:"<<endl;
cin>>e; 
Push(S,e);
cout<<"链表进栈完成:"<<endl; 
PrintStack(S);
//链表出栈cout<<"链表出栈"<<endl;
cout<<"链表出栈完成:"<<endl;
Pop(S,e);
cout<<e<<endl; 
//获取链栈栈顶元素cout<<"获取链栈栈顶元素完成:"<<endl;
GetTop(S,e);
cout<<e<<endl; 
return0;
}

编译运行

20201112155311187.gif


目录
相关文章
|
C语言
【C语言刷题系列】删除公共元素
【C语言刷题系列】删除公共元素
|
存储 C语言 C++
【C++数据结构——栈与队列】链栈的基本运算(头歌实践教学平台习题)【合集】
本关任务:编写一个程序实现链栈的基本运算。开始你的任务吧,祝你成功!​ 相关知识 初始化栈 销毁栈 判断栈是否为空 进栈 出栈 取栈顶元素 初始化栈 概念:初始化栈是为栈的使用做准备,包括分配内存空间(如果是动态分配)和设置栈的初始状态。栈有顺序栈和链式栈两种常见形式。对于顺序栈,通常需要定义一个数组来存储栈元素,并设置一个变量来记录栈顶位置;对于链式栈,需要定义节点结构,包含数据域和指针域,同时初始化栈顶指针。 示例(顺序栈): 以下是一个简单的顺序栈初始化示例,假设用C语言实现,栈中存储整数,最大
362 9
|
存储 算法 Java
Set接口及其主要实现类(如HashSet、TreeSet)如何通过特定数据结构和算法确保元素唯一性
Java Set因其“无重复”特性在集合框架中独树一帜。本文解析了Set接口及其主要实现类(如HashSet、TreeSet)如何通过特定数据结构和算法确保元素唯一性,并提供了最佳实践建议,包括选择合适的Set实现类和正确实现自定义对象的hashCode()与equals()方法。
468 4
【数据结构OJ题】移除链表元素
力扣题目——移除链表元素
186 2
【数据结构OJ题】移除链表元素
|
算法
【数据结构OJ题】移除元素
力扣题目——移除元素
149 1
【数据结构OJ题】移除元素
|
存储 C语言
【数据结构】c语言链表的创建插入、删除、查询、元素翻倍
【数据结构】c语言链表的创建插入、删除、查询、元素翻倍
342 0
【数据结构】c语言链表的创建插入、删除、查询、元素翻倍
|
存储 C语言
【C语言刷题系列】求一个数组中两个元素a和b的和最接近整数m
【C语言刷题系列】求一个数组中两个元素a和b的和最接近整数m
|
算法
【数据结构与算法 刷题系列】移除链表元素
【数据结构与算法 刷题系列】移除链表元素
|
C语言
【C语言刷题系列】移除元素
【C语言刷题系列】移除元素
|
存储 算法
非递归实现后序遍历时,如何避免栈溢出?
后序遍历的递归实现和非递归实现各有优缺点,在实际应用中需要根据具体的问题需求、二叉树的特点以及性能和空间的限制等因素来选择合适的实现方式。
419 59