当前位置: 首页 > news >正文

无锡大型网站建设公司wordpress视频类模板下载

无锡大型网站建设公司,wordpress视频类模板下载,媒体广告投放平台,中国价格信息网目录 1.栈的概念及结构 2.栈的实现 2.1栈结构定义 2.2初始化及销毁 2.3插入数据 2.4删除数据 2.5访问栈顶数据 2.6判断是否为空栈 2.7计算栈的大小 3.8访问栈中所有数据 1.栈的概念及结构 栈:栈是一种特殊的线性表,其只允许在固定的一端进行插…

目录

1.栈的概念及结构

2.栈的实现

2.1栈结构定义

2.2初始化及销毁

2.3插入数据

2.4删除数据

2.5访问栈顶数据

2.6判断是否为空栈

2.7计算栈的大小

3.8访问栈中所有数据


1.栈的概念及结构

栈:栈是一种特殊的线性表,其只允许在固定的一端进行插入和删除操作

进行数据插入和删除操作的一端称为栈顶,另一端称为栈底

栈中的数据元素遵守后进先出LIFO(Last  In First Out)的原则

压栈:栈的插入操作叫做进栈/压栈/入栈,插入数据在栈顶

出栈:栈的删除操作叫做出栈,删除数据也在栈顶

如下图为一个栈的结构:

上图中入栈顺序为:123456789

出栈顺序为:987654321

区分数据结构中的栈和内存中的栈:

内存区域划分:堆区,栈区,静态区,常量区......

一般操作系统中的栈指的是内存中的栈,数据结构中的栈是可以插入删除数据的栈

2.栈的实现

栈的实现一般可以使用数组或者链表实现,使用数组在尾插数据时的代价比较小,所以一般使用数组实现栈

2.1栈结构定义

栈结构的定义分为静态开辟和动态开辟两种

静态开辟时栈的空间大小是固定的,所以一般情况我们使用动态开辟

动态开辟的栈结构包括三个成员变量:数组指针,可以访问栈顶的top,栈的当前容量

📖Note:

我们创建的栈结构是数组形式的,所以可以通过下标访问,top即为时刻指向栈顶的下标

top也可以看作为栈中实际元素的个数

typedef int  STDataType;
//静态开辟
#define N 100
struct Stack
{STDataType a[N];int top;
};//动态内存开辟
typedef struct Stack
{STDataType* a;int top;int capacity;
}ST;

2.2初始化及销毁

初始化时对三个成员变量都要进行初始化

数组指针初始化为NULL

top = 0,同时指向栈底和栈顶,top可以看作为栈中实际元素的个数栈顶是动态变化的,每次插入数据或删除数据栈顶都会发生变化,而栈底是相对固定不变的

初始化时栈的容量为0,需要使用栈时再动态开辟空间

销毁时同样对三个结构成员分别置空或置0

//初始化
void StackInit(ST* ps)
{assert(ps);ps->a = NULL;ps->top = ps->capacity = 0;
}
//销毁
void StackDestroy(ST* ps)
{assert(ps);free(ps->a);ps->a = NULL;ps->top = ps->capacity = 0;
}

2.3插入数据

插入数据首先要扩容,第一次插入我们开辟4个空间(根据需求),其他情况扩容为原来的二倍

📖Note:

以下代码中realloc的第二个参数应该是newcapacity * sizeof(STDataType)而不newcapacity

使用realloc函数扩容,第二个参数的单位是字节,是我们开辟空间的总字节数

扩容失败直接退出函数即可

扩容成功才可以插入数据

数组形式的栈中数据访问通过下标访问,栈结构的特殊性使其只能在栈顶进行数据的插入和删除,而top正是时刻指向栈顶的下标,所以使数据的插入和删除更加方便

//插入数据
void StackPush(ST* ps, STDataType x)
{assert(ps);//扩容if (ps->top == ps->capacity){int newcapacity = ps->capacity == 0 ? 4 : (ps->capacity) * 2;STDataType* tmp = realloc(ps->a, newcapacity * sizeof(STDataType));//扩容失败if (tmp == NULL){perror("realloc fail");exit(-1);}//扩容成功ps->a = tmp;ps->capacity = newcapacity;}//插入数据ps->a[ps->top] = x;ps->top++;
}

下图是将12345一次压栈后栈中的结构 

2.4删除数据

数据的删除就更加方便,只要栈非空,指向栈顶的top直接向栈底方向移动一块空间即可

//删除数据
void StackPop(ST* ps)
{assert(ps);//栈不为空才能删除assert(!StackEmpty(ps));--ps->top;
}

2.5访问栈顶数据

访问栈顶数据的前提也是栈非空

注意数组的下标与元素的对应关系,数组的下标从0开时,所以第n个元素对应下标n-1

//访问栈顶数据
STDataType StackTop(ST* ps)
{assert(ps);//栈不为空才能访问assert(!StackEmpty(ps));return ps->a[ps->top - 1];
}

2.6判断是否为空栈

当栈中实际元素的个数为0时,栈即为空栈

//判断是否为空栈
bool StackEmpty(ST* ps)
{assert(ps);return ps->top == 0;
}

2.7计算栈的大小

栈的大小即为栈中实际元素的个数,所以返回ps->top即可

//计算栈的大小
int StackSize(ST* ps) 
{assert(ps);return ps->top;
}

3.8访问栈中所有数据

栈中数据的访问只能从栈顶,当栈非空时,每次访问栈顶元素即可,访问栈顶的下一个元素需要栈顶元素先出栈,直至栈为空停止访问

//访问栈中数据
void StackPopAll(ST* ps)
{while (!StackEmpty(ps)){printf("%d ", StackTop(ps));StackPop(ps);}printf("\n");
}

 

http://www.yayakq.cn/news/748792/

相关文章:

  • asp.net网站开发期末复习题什么网页可以做网站
  • 参考消息官方网站阅读个体户可以网站备案吗
  • 做一般的公司门户网站投资额河北邯郸最新消息
  • 免费做宣传的网站是我现在有域名怎么做网站
  • 仓山区城乡建设局网站哪个网站做海南二手房
  • 网站开发发展前景国外网站服务器
  • 杨和勒流网站建设怎么是营销型网站建设
  • 北京 网站 外包服务器租用相关网站
  • 有漏洞的网站建大型网站需要多少钱
  • 凡科建站视频教程jquery 素材的网站
  • 通辽网站建设wordpress幻灯片满屏
  • 潜江网站设计公司vs2013网站开发
  • html5国内网站欣赏做ic什么网站好
  • 北京网站建设 云智互联腾讯学生服务器可以做网站吗
  • linux建设一个网站wordpress菜单底部导航代码
  • 网站后台数据库备份怎么做外贸网站建设需要注意什么
  • 自助网站开发帝国cms官网
  • 响应式网站开发源码html做一个学校网页
  • 做盗版小说网站违法吗课程网页界面设计
  • .net网站开发框架教育网站建设的意义
  • 网站模板 wordpress带会员系统湖南建立网站营销策划
  • 盈利网站南宁站建好就够用
  • 企业网站关键词排名 s重庆最新情况 最新消息
  • 网站商品图片尺寸网站建设编辑器
  • wampserver网站开发步骤网站开发的配置过程
  • 专业网站快速广州通app下载
  • 济南市城乡建设部网站首页装修论坛
  • 广州网站推广模板电商网站建设基础教案
  • 设计类书籍网站做网站的商家怎么赚取流量费
  • 做淘宝网站需要多少钱网络营销渠道也可分为