数据结构(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


目录
相关文章
|
2月前
|
存储 算法 Java
Set接口及其主要实现类(如HashSet、TreeSet)如何通过特定数据结构和算法确保元素唯一性
Java Set因其“无重复”特性在集合框架中独树一帜。本文解析了Set接口及其主要实现类(如HashSet、TreeSet)如何通过特定数据结构和算法确保元素唯一性,并提供了最佳实践建议,包括选择合适的Set实现类和正确实现自定义对象的hashCode()与equals()方法。
45 4
|
6月前
|
算法 Unix Linux
C语言随机数的产生(rand、srand、time函数细节讲解)
C语言随机数的产生(rand、srand、time函数细节讲解)
129 0
|
6月前
|
算法
数据结构和算法学习记录——习题-移除链表元素
数据结构和算法学习记录——习题-移除链表元素
28 0
|
3月前
|
存储 编译器 C语言
【C语言基础考研向】07逻辑运算符与赋值运算符
本文介绍了C语言中的逻辑运算符与逻辑表达式、赋值运算符以及求字节运算符`sizeof`。逻辑运算符包括`!`(逻辑非)、`&&`(逻辑与)和`||`(逻辑或),其优先级规则与数学运算符类似。通过示例展示了如何用这些运算符判断闰年及逻辑非的运算方向。此外,文章还解释了左值与右值的概念及其在赋值运算中的应用,并介绍了复合赋值运算符的使用方法,如加后赋值`+=`和乘后赋值`*=`。最后,通过`sizeof`运算符示例展示了如何获取变量的字节大小。
|
4月前
|
C语言
C语言结构体赋值的四种方式
本文总结了C语言结构体的四种赋值方式,并通过示例代码和编译运行结果展示了每种方式的特点和效果。
396 6
|
4月前
|
存储 C语言
【数据结构】c语言链表的创建插入、删除、查询、元素翻倍
【数据结构】c语言链表的创建插入、删除、查询、元素翻倍
【数据结构】c语言链表的创建插入、删除、查询、元素翻倍
|
5月前
【数据结构OJ题】移除链表元素
力扣题目——移除链表元素
49 2
【数据结构OJ题】移除链表元素
|
5月前
|
算法
【数据结构OJ题】移除元素
力扣题目——移除元素
38 1
【数据结构OJ题】移除元素
|
6月前
|
搜索推荐 程序员 C语言
指针赋值与引用传递:C语言的基础知识与实践技巧
指针赋值与引用传递:C语言的基础知识与实践技巧
|
6月前
|
存储
数据结构学习记录——堆的插入(堆的结构类型定义、最大堆的创建、堆的插入:堆的插入的三种情况、哨兵元素)
数据结构学习记录——堆的插入(堆的结构类型定义、最大堆的创建、堆的插入:堆的插入的三种情况、哨兵元素)
45 2