数据结构(3)(顺序栈)
创始人
2024-11-19 07:07:37
0

 栈:

      栈是限定仅在栈顶进行插入和删除操作的线性表,在操作的时候,只允许栈顶改变不允许栈底改变,具有后进先出的特征。

顺序栈:

      顺序栈是一种使用数组实现的栈,也称为数组栈。其基本思路是通过数组来存储栈中的元素,并通过栈顶指针指示栈顶元素在数组中的位置。

     也就是说,相当于只能对最后一个元素进行增,删,查的数组。

基本操作:

#ifndef SEQSTACK_H #define SEQSTACK_H  typedef struct{     char name[32];     char sex;     int age;     int score; }DATATYPE;  typedef struct {    DATATYPE* head;    int tlen;    int top;// clen }SeqStack;  SeqStack*CreateSeqStack(int size);  //创建 int DestroySeqStack(SeqStack*ss);  //销毁 int PushSeqStack(SeqStack*ss,DATATYPE*data);  //入栈 int PopSeqStack(SeqStack*ss);  //出栈 int IsEmptySeqStack(SeqStack*ss);  //判断栈是否为空 int IsFullSeqStack(SeqStack*ss);  //判断栈是否为满 int GetSizeSeqStack(SeqStack*ss);  //获取栈当前大小 DATATYPE*GetTopSeqStack(SeqStack*ss);  //获取栈顶元素 #endif // SEQSTACK_H

实现:

#include "seqstack.h" #include  #include  #include  SeqStack *CreateSeqStack(int size) {     SeqStack* ss = ( SeqStack*)malloc(sizeof(SeqStack));     if(NULL ==ss)     {         perror("CreateSeqStack error malloc1");         return NULL;     }     ss->head = ( DATATYPE*)malloc(sizeof(DATATYPE)*size);     if(NULL ==ss->head)     {         perror("CreateSeqStack error malloc2");         return NULL;     }     ss->tlen = size;     ss->top =  0;     return ss; }  int PushSeqStack(SeqStack *ss, DATATYPE *data) {     if(NULL == ss ||NULL ==data)     {         fprintf(stderr,"SeqStack or data  is null \n");         return 1;     }     if(IsFullSeqStack(ss))     {         fprintf(stderr,"PushSeqStack full\n");         return 1;     }      memcpy(&ss->head[ss->top],data,sizeof(DATATYPE));     ss->top++;     return 0; }  int PopSeqStack(SeqStack *ss) {     if(NULL == ss )     {         fprintf(stderr,"SeqStack  is null \n");         return 1;     }     if(IsEmptySeqStack(ss))     {         fprintf(stderr,"PopSeqStack is empty \n");         return 1;     }     ss->top--;     return 0; }  int IsEmptySeqStack(SeqStack *ss) {     return 0 == ss->top; }  int IsFullSeqStack(SeqStack *ss) {     return ss->top == ss->tlen; }  DATATYPE *GetTopSeqStack(SeqStack *ss) {     if(IsEmptySeqStack(ss))     {         return NULL;     }     return &ss->head[ss->top-1]; }

相关内容

热门资讯

新2024版措施!微扑克代打是... 新2024版措施!微扑克代打是真的的(辅助挂)指尖跑得快能控制输赢的(有挂技巧);人气非常高,ai更...
第三方介绍!wpk辅助机器人(... 【福星临门,好运相随】;第三方介绍!wpk辅助机器人(有科技)全民如意棋牌攻略(有挂手段);暗藏猫腻...
五分钟了解!wepoke软件机... 1、不需要AI权限,帮助你快速的进行wepoke计算辅助教程,沉浸在游戏的游玩之中。2、里面整个we...
科技分享!wepoke有规律的... 科技分享!wepoke有规律的(有挂的)星悦手机麻将是挂(有挂指点);wepoke软件透明挂作为一款...
一分钟教会你!微扑克德州专用辅... 1、不需要AI权限,帮助你快速的进行微扑克计算辅助教程,沉浸在游戏的游玩之中。2、里面整个微扑克黑科...
透视辅助!wpk辅助软件(软件... 1、完成算番宝典的残局,帮助玩家取得所有比赛的胜利,直登高塔的教程。2、多达1000个不同的游戏攻略...
黑客什么是渗透 黑客渗透是指黑客通过技术手段,利用系统的漏洞或弱点,非法进入目标计算机系统、网络或数据库,获取、篡改...
第三方规律!微扑克线上代打工具... 一、第三方规律!微扑克线上代打工具(软件透明挂)胡乐麻将有挂的(有挂指南)AI软件牌型概率发牌机制”...
oppo手机nfc在哪打开(如... 在OPPO手机上,通常可以在设置中找到NFC选项。进入“设置”-“连接与共享”-确定“NFC”为开启...
韩小陌百科 韩小陌,1994年2月10日出生于黑龙江省哈尔滨市,毕业于北京现代音乐学院,中国内地女演员、歌手。韩...