栈(Stack)

只允许在一端进行插入或删除操作的线性表

栈顶(Top):栈中允许进行插入和删除操作的那一端;

栈底(Bottom):固定的,不允许进行插入或删除的另一端

1.栈是受限的线性表,所以自然具有线性关系。

2.栈中元素后进先出。

栈的顺序存储==顺序栈

#define MaxSize 50             //定义栈中元素的最大个数
typedef struct{
Elemtype data[MaxSize]; //存放栈中元素
}Sqstack; //顺序栈简写

1.Top的值不能超过MaxSize;

2.空栈的判定条件通常为top==-1,满栈的判定条件为top=MaxSize-1,栈中元素个数为top+1.

顺序栈的操作:

1.判空

bool StackEmpty(SqStack S){
if(S.top==-) return true;
else return false;
}

2.进栈

bool Push(SqStack &S,Elemtype x){
if(S.top==MaxSize-) return false;
S.data[++S.top]=x; return true;
}

3.出栈

bool Pop(SqStack &S,Elemtype &x){
if(S.top==-) return false;
x=S.data[S.top--]; return true;
}

4.读取栈顶元素

bool GetTop(SqStack S,Elemtype &x){
if(S.top==-) return false;
x=S.data[S.top];return true;
}

共享栈

顺序栈的存储空间大小需要事先开辟好,对每个栈各自单独开辟存储空间的利用率不如将各个栈存储空间共享。

栈满条件下:指针top1与指针top2只相差1,即top1+1=top2.

结构:

#define MaxSize 100            //定义栈中元素的最大个数
typedef struct{
Elemtype data[MaxSize]; //存放栈中元素
int top1;
int top2;
}SqDoublestack; //顺序共享栈简写

进栈:

bool Push(SqDoubleStack &S,ElemType x,int stackNum0{
if(S.top1+=S.top2) return false;
if(stackNum==) S.data[++S.top1]=x;//栈1有元素进栈
if(stackNum==) S.data[++S.top2]=x;//栈2有元素进栈
return true;
}

栈的链式存储==链栈

头指针当作栈顶指针,栈顶存放在单链表头部。

typedef struct SNode{
ElemType data; //存放栈中元素
struct SNode *next; //栈顶指针
}SNode *SLink //链栈的结点 typedef struct LinkStack{
SLink top; //栈顶指针
int count; //链栈结点数
}LinkStack //链栈

1.链栈一般不存在满栈

2.空栈的判定关系一般为top=NULL

进栈

bool Push(LinkStack &S,ElemType x){
SLink p=(SLink)mallo((sizeof(SNode));//给新元素分配空间
p->data=x; //新元素的值
p->next=s->top; //p的后继指针指向新的元素
s->top=p; //栈顶指针指向新的元素
s->count++; //栈中元素加1
return true;
}

出栈

bool Pop(LinkStack &S, ElemType &x){
if(S->top==NULL) return false;
x=S->top->data; //栈顶元素值
Slink p=S->top; //辅助指针
S->top=S->top->next; //栈顶指针后移
free(p); //释放被删除数据的存储空间
S->count--; 栈中元素个数减1
return true;
}

c语言数据结构学习心得——栈的更多相关文章

  1. c语言数据结构学习心得——二叉树

    二叉树 n(n>=0)个结点的有限集合:(五种形态) 1.或者为空二叉树,n=0: 2.或者由一个根结点和两个互不相交的被称为根的左子树和右子树组成.左子树和右子树又分别是一棵二叉树. 3.每个 ...

  2. c语言数据结构学习心得——图

    图G由顶点集V和边集E组成,记为G=(V,E) 图不可为空,一定有顶点集不为空 有向图:有向边(弧)的有限集合 无向图:无向边的有限集合 连通:顶点V到顶点V'有路径 连通分量:无向图中的极大连通子图 ...

  3. c语言数据结构学习心得——排序

    排序:将无序的序列重新排列为有序的序列. 插入类排序 插入类排序:在一个有序的序列中,插入一个新的关键字,知道所有的关键字都插入形成一个有序的序列. 直接插入排序:首先以一个元素为有序的序列,然后将后 ...

  4. c语言数据结构学习心得——查找

    顺序查找(线性查找) 主要用于在线性表中的查找 int Search1(int a[],int n,int key){ ;i<=n;i++){ //注意从1开始 if(a[i]==key)ret ...

  5. c语言数据结构学习心得——树

    树 一对多的树型结构,有且只有一个特定的根结点. 结点的度:结点拥有子树的数量{ 度为0:叶子结点/终端结点. 度不为0:非终端结点/分支结点(除去根结点其它称为内部结点).} 树的度:树中所有结点的 ...

  6. c语言数据结构学习心得——队列

    队列 只允许在一端进行插入,在另一端进行删除的线性表 队头(Front):允许删除的一端(队首) 队尾(Rear):允许插入的一端 FIFO:先进先出 不要求从数组首位开始存储队列 #define M ...

  7. c语言数据结构学习心得——线性表

    线性表:具有相同数据类型的n(n>0)个数据元素的有限序列. 主要有顺序存储和链式存储. 顺序存储: 特点:地址连续,随机/存取,顺序存储. 建立:首地址/存储空间大小(数组),表长. 方式:静 ...

  8. c语言数据结构学习心得——数据结构基本概念

    1.数据>数据元素>数据项      数据的基本单位是数据元素,数据元素的基本单位是数据项 2.运算的定义->针对逻辑结构 集合:同属于一个集合,无其他关系.(数学上的集合) 线性结 ...

  9. 数据结构学习之栈求解n皇后问题

    数据结构学习之栈求解n皇后问题 0x1 目的 ​ 深入掌握栈应用的算法和设计 0x2 内容 ​ 编写一个程序exp3-8.cpp求解n皇后问题. 0x3 问题描述 即在n×n的方格棋盘上,放置n个皇后 ...

随机推荐

  1. 【279】◀▶ Python 运算符说明

    参考:Python 运算符说明 目录: 一.算术运算符 二.比较(关系)运算符 三.赋值运算符 四.位运算符 五.逻辑运算符 六.成员运算符 七.身份运算符 八.运算符优先级 一.Python 算术运 ...

  2. 设备控制接口ioctl详解

    [转]Linux设备控制接口 序言设备驱动程序的一个基本功能就是管理和控制设备,同时为用户应用程序提供管理和控制设备的接口.我们前面的“Hello World”驱动程序已经可以提供读写功能了,在这里我 ...

  3. 生成ssl脚本文件

    read -p "Enter your domain [www.example.com]: " DOMAIN echo "Create server key...&quo ...

  4. 张超超OC基础回顾01_类的创建,申明属性,以及本质

    一. 类的声明和实现&规则 1.如何编写类的声明 以@interface开头 , 以@end结尾, 然后再class name对应的地方写上 事物名称, 也就是类名即可 注意: 类名的首字符必 ...

  5. grid search 超参数寻优

    http://scikit-learn.org/stable/modules/grid_search.html 1. 超参数寻优方法 gridsearchCV 和  RandomizedSearchC ...

  6. 卡2-SLAM

    ---恢复内容开始--- 1.下载 首先需要从github上Git以下两个包: git clonehttps://github.com/ros-perception/open_karto(开源的kar ...

  7. eclipse——执行Maven命令

    右键pom.xml文件 点击 m2 Maven build... 输入要执行的命令,点击Run 控制台会打印maven运行过程

  8. 智能IC卡中的文件系统

    1.文件系统是COS的重要模块之一,它负责组织.管理.维护IC卡内存储的所有数据. 文件系统的设计和实现既是COS系统中最灵活.最有个性的部分,也是对系统整体结构影响最大的模块之一. 2.在IC卡内, ...

  9. 第16章-使用Spring MVC创建REST API

    1 了解REST 1.1 REST的基础知识 REST与RPC几乎没有任何关系.RPC是面向服务的,并关注于行为和动作:而REST是面向资源的,强调描述应用程序的事物和名词. 为了理解REST是什么, ...

  10. Adorner的收集

    Adorners Overview https://docs.microsoft.com/en-us/dotnet/framework/wpf/controls/adorners-overview ' ...