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

相关内容

热门资讯

透视挂透视!情怀怎么开挂,一起... 1、透视挂透视!情怀怎么开挂,一起宁德钓蟹辅助器,解密教程(有挂攻略)2、进入游戏-大厅左侧-新手福...
第十分钟辅助!广东雀神智能插件... 第十分钟辅助!广东雀神智能插件辅助脚本(辅助挂)其实是有挂(详细辅助2025新版)是一款可以让一直输...
一分钟秒懂“微乐小程序辅助开发... 自定义微乐小程序辅助开发系统规律,只需要输入自己想要的开挂功能,一键便可以生成出微扑克专用辅助器,不...
第2分钟辅助(乐乐川南字牌辅助... 第2分钟辅助(乐乐川南字牌辅助器)总是存在有挂(详细辅助必胜教程)乐乐川南字牌辅助器是一种具有地方特...
第二分钟辅助!微信小程序雀神麻... 第二分钟辅助!微信小程序雀神麻将好运来(辅助挂)原先有挂(详细辅助线上教程);第二分钟辅助!微信小程...
透视新版!智星德州插件最新版本... 透视新版!智星德州插件最新版本更新内容详解,广东雀神智能插件免费,切实教程(有挂介绍)1、广东雀神智...
透视智能ai!欢乐达人怎么开辅... 透视智能ai!欢乐达人怎么开辅助,决战卡五星辅助,德州教程(有挂辅助);欢乐达人怎么开辅助软件透明挂...
科技分享“越乡游义乌辅助器微信... 1、科技分享“越乡游义乌辅助器微信免费”wepoker私人局俱乐部怎么进(本然真的有挂);详细教程。...
8分钟辅助(微乐小程序免费黑科... 8分钟辅助(微乐小程序免费黑科技)真是真的有挂(详细辅助详细教程)1、构建自己的微乐小程序免费黑科技...
透视辅助!微扑克微乐辅助,边锋... 透视辅助!微扑克微乐辅助,边锋干瞪眼辅助,必胜教程(有挂插件)透视辅助!微扑克微乐辅助,边锋干瞪眼辅...