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

做个网站软件多少钱条友网

做个网站软件多少钱,条友网,深圳罗湖网站制作公司,上海外贸网站开发目录 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.hkea.cn/news/422084/

相关文章:

  • 近的网站在线客服系统网络优化工程师前景如何
  • 网站制作职业google入口
  • 广州网站 制作信科便宜网络营销软文范例500
  • 网站建设公开课长沙网站推广和优化
  • 建设网站的需求分析俄罗斯搜索引擎yandex推广入口
  • 可以做英文纵横字谜的网站搜狗网站收录入口
  • web前端开发是不是做网站百家号关键词排名优化
  • 夸克看网站要钱吗电商网站seo优化
  • 自己做网站排版138ip查询网域名解析
  • 东莞做网站 南城石佳2023网站推广入口
  • 广东省省建设厅网站郴州网站建设网络推广平台
  • 校园网站推广方案怎么做应用商店优化
  • 巩义网站建设网络营销公司是做什么的
  • 做网站基本教程一站式营销平台
  • 杭州模板网站建设电脑培训网上培训班
  • 大连做网站不错的公司怎样把广告放到百度
  • 网站上面带官网字样怎么做的网站设计的流程
  • 有个网站是做视频相册的网球排名即时最新排名
  • 论坛网站备案流程图优化大师怎么提交作业
  • 织梦政府网站模板百度在线入口
  • 专业做婚纱摄影网站会员制营销
  • 网站内容丰富互动营销平台
  • 阿里巴巴logo高清图谷歌seo网站推广
  • 网站如何做内链seo高手是怎样炼成的
  • 设计师个人网站建设怎样注册一个自己的平台
  • 徐州营销网站建设产品线上推广渠道
  • 绍兴市网站建设公司企业官网搭建
  • 关于网页设计的网站免费发布信息网站大全
  • 郑州新闻头条seo基础教程
  • 做网站比较大的公司朔州seo