数据结构(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分钟了解!火神大厅外g挂(... 第1分钟了解!火神大厅外g挂(辅助)天天黄石麻将开挂辅助修改器-总是是有软件1、火神大厅外g挂辅助器...
6分钟了解!手游游戏挂机辅助(... 6分钟了解!手游游戏挂机辅助(辅助)福运开挂辅助辅助-切实存在有插件6分钟了解!手游游戏挂机辅助(辅...
第四分钟了解!创思维激k怎么开... 第四分钟了解!创思维激k怎么开挂(辅助)JJ斗地主开挂辅助安装-都是真的是有下载1、每一步都需要思考...
第八分钟了解!皇豪互众智能辅助... 第八分钟了解!皇豪互众智能辅助器破解(辅助)星火燎原开挂辅助下载-本来是真的神器1、皇豪互众智能辅助...
三分钟了解!途游大作战辅助(辅... 三分钟了解!途游大作战辅助(辅助)中至余干麻将开挂辅助软件-都是有挂平台1、让任何用户在无需途游大作...
6分钟了解!推荐一下胡乐辅助脚... 6分钟了解!推荐一下胡乐辅助脚本的教程(辅助)达达开挂辅助辅助器-果然存在有平台1、玩家可以在推荐一...
六分钟了解!衢州都莱罗松怎么才... 六分钟了解!衢州都莱罗松怎么才能赢(辅助)白金岛游戏开挂辅助脚本-确实是有平台该软件可以轻松地帮助玩...
第9分钟了解!天天透视辅助工具... 第9分钟了解!天天透视辅助工具(辅助)大巴斗地主开挂辅助修改器-一贯是真的软件1、金币登录送、破产送...
第四分钟了解!乐酷辅助(辅助)... 第四分钟了解!乐酷辅助(辅助)新时代开挂辅助脚本-都是真的是有辅助第四分钟了解!乐酷辅助(辅助)新时...
十分钟了解!决战十水三余音(辅... 十分钟了解!决战十水三余音(辅助)8522TV开挂辅助辅助器-总是是有辅助器1、游戏颠覆性的策略玩法...