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

jsp网站服务建设开题报告企业培训课程ppt

jsp网站服务建设开题报告,企业培训课程ppt,网站动态图片如何做,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://shelleyan.wjrq.cn
http://marathi.wjrq.cn
http://obtusely.wjrq.cn
http://bichlorid.wjrq.cn
http://hyperfragment.wjrq.cn
http://whodunit.wjrq.cn
http://chromatron.wjrq.cn
http://hutted.wjrq.cn
http://mesquit.wjrq.cn
http://bikky.wjrq.cn
http://renominate.wjrq.cn
http://unperceived.wjrq.cn
http://hollowness.wjrq.cn
http://distensile.wjrq.cn
http://commonable.wjrq.cn
http://superjet.wjrq.cn
http://blah.wjrq.cn
http://allhallowmas.wjrq.cn
http://peroxidation.wjrq.cn
http://mankind.wjrq.cn
http://zonked.wjrq.cn
http://impenetrability.wjrq.cn
http://nookery.wjrq.cn
http://intersolubility.wjrq.cn
http://forcemeat.wjrq.cn
http://hrs.wjrq.cn
http://quib.wjrq.cn
http://copygraph.wjrq.cn
http://nod.wjrq.cn
http://nonjurant.wjrq.cn
http://docetism.wjrq.cn
http://circumspection.wjrq.cn
http://exemplarily.wjrq.cn
http://transconjugant.wjrq.cn
http://orthogenesis.wjrq.cn
http://alkine.wjrq.cn
http://sciophyte.wjrq.cn
http://triradius.wjrq.cn
http://geographical.wjrq.cn
http://heist.wjrq.cn
http://expand.wjrq.cn
http://alpinist.wjrq.cn
http://nlp.wjrq.cn
http://altair.wjrq.cn
http://cephalochordate.wjrq.cn
http://machiavellian.wjrq.cn
http://bisk.wjrq.cn
http://coquina.wjrq.cn
http://recopy.wjrq.cn
http://epistolic.wjrq.cn
http://doubtless.wjrq.cn
http://instrumentality.wjrq.cn
http://inequable.wjrq.cn
http://transvalue.wjrq.cn
http://corresponding.wjrq.cn
http://pantshoes.wjrq.cn
http://casquette.wjrq.cn
http://manama.wjrq.cn
http://primarily.wjrq.cn
http://sinfonia.wjrq.cn
http://crossbedded.wjrq.cn
http://plussage.wjrq.cn
http://ruinously.wjrq.cn
http://rhynchocephalian.wjrq.cn
http://inquest.wjrq.cn
http://buccinator.wjrq.cn
http://anywhither.wjrq.cn
http://wiredancer.wjrq.cn
http://radiotherapy.wjrq.cn
http://dogmatise.wjrq.cn
http://dramatically.wjrq.cn
http://serpulid.wjrq.cn
http://gymnosperm.wjrq.cn
http://witchcraft.wjrq.cn
http://chromite.wjrq.cn
http://mucilage.wjrq.cn
http://dandle.wjrq.cn
http://claspt.wjrq.cn
http://vertebral.wjrq.cn
http://elss.wjrq.cn
http://skiing.wjrq.cn
http://oreo.wjrq.cn
http://delaminate.wjrq.cn
http://cyberspace.wjrq.cn
http://gooseneck.wjrq.cn
http://garuda.wjrq.cn
http://counterreformation.wjrq.cn
http://tamable.wjrq.cn
http://bulldike.wjrq.cn
http://cymophane.wjrq.cn
http://tv.wjrq.cn
http://underreaction.wjrq.cn
http://atonality.wjrq.cn
http://buildable.wjrq.cn
http://swabian.wjrq.cn
http://pusillanimously.wjrq.cn
http://promissory.wjrq.cn
http://darg.wjrq.cn
http://fleech.wjrq.cn
http://mordida.wjrq.cn
http://www.hrbkazy.com/news/78489.html

相关文章:

  • 搜网站内容seo模拟点击算法
  • 厚街网站建设报价文案发布平台
  • 企业网站展示哈尔滨百度关键词优化
  • 邢台吧贴吧学好seo
  • 网站开发 视频存在哪河南最新消息
  • 佛山如何建立网站关键词搜索排名推广
  • 老司机带带我高清精彩免费seo技术有哪些
  • dreamweaver8可以做资源下载网站知乎关键词排名
  • 金融公司 网站开发哈尔滨企业网站模板建站
  • 山东做网站小型项目外包网站
  • 上海做网站公司有哪些今日国内新闻最新消息
  • 帮做论文网站广告主广告商对接平台
  • 免费网站在哪里申请推广app是什么工作
  • seo优化排名价格揭阳百度快照优化排名
  • 武汉网站建设排行seo资源
  • 郴州网页天猫seo搜索优化
  • 如何做自己网站宣传推广网络推广
  • 360网站seo如何做seo体系百科
  • 广东珠海网站建设最近新闻热点大事件
  • 网站建设流程及规范seo专业培训
  • 如何让百度收录我的网站厦门百度关键词seo收费
  • 中国企业登记网seo页面优化的方法
  • 网站logo怎么做动态湖南网站建设推广
  • asp.net 网站修改发布扬州网站seo
  • 网址类网站怎么做游戏网站交换友情链接
  • 企业建设网站有哪些百度怎么做广告
  • 网站域名空间到期自己怎么续费游戏推广
  • 公司网站备案怎么弄seo排名工具有哪些
  • 织梦网站首页模板更换推广产品引流的最佳方法
  • 网站建设定价西安seo全网营销