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

重庆自助企业建站模板365优化大师软件下载

重庆自助企业建站模板,365优化大师软件下载,广东网站建设,邯郸建设信息网站文章目录 前言概述栈的初始化销毁压栈出栈判断栈为不为空栈的有效个数 前言 栈相对于链表,稍微简单一点,但是栈的难点在于通过栈去理解递归算法。 概述 **栈:**一种特殊的线性表,其只允许在固定的一端进行插入和删除元素操作。…

在这里插入图片描述

文章目录

  • 前言
  • 概述
  • 栈的初始化
  • 销毁
  • 压栈
  • 出栈
  • 判断栈为不为空
  • 栈的有效个数

前言

栈相对于链表,稍微简单一点,但是栈的难点在于通过栈去理解递归算法。

概述

**栈:**一种特殊的线性表,其只允许在固定的一端进行插入和删除元素操作。进行数据插入和删除操作的一端称为栈顶,另一端称为栈底。栈中的数据元素遵守 后进先出 LIFO(Last In First Out)的原则。

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

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

在这里插入图片描述

栈的实现一般可以使用数组或者链表实现,相对而言数组的结构实现更优一些。因为数组在尾上插入数据的代价比较小。

在这里插入图片描述

栈的初始化

初始化在c语言中需要动态开辟内存

top是栈顶,记录当前数据个数,但是需要注意的是:

  • 如果初始化成0,那么这个 top 就指的是栈顶的下一个位置;

在这里插入图片描述

  • 如果初始化成-1,那么这个 top 就指的是栈顶的位置;

在这里插入图片描述
初始化的容量和顺序表操作一样

void STInit(ST* pst)
{assert(pst);pst->a = NULL;pst->capacity = 0;// 表示top指向栈顶元素的下一个位置pst->top = 0;// 表示top指向栈顶元素//pst->top = -1;
}

销毁

void STDestroy(ST* pst)
{assert(pst);free(pst->a);pst->a = NULL;pst->top = pst->capacity = 0;
}

压栈

压栈的时候需要先判断栈满不满,判断条件pst->top == pst->capacity

如果满了,则需要开辟空间

不满则直接压入栈顶即可。

需要注意的是:

  • 如果初始化成0,先将栈顶top往后移动,top++,再将x压入栈中,a[top]=x

  • 如果初始化成-1,先将c压入栈中,a[top]=x,再移动栈顶,top++

void STPush(ST* pst, STDataType x)
{assert(pst);if (pst->top == pst->capacity){int newcapacity = pst->capacity == 0 ? 4 : pst->capacity * 2;STDataType* tmp = (STDataType*)realloc(pst->a, sizeof(STDataType) * newcapacity);if (tmp == NULL){perror("realloc fail");return;}pst->a = tmp;pst->capacity = newcapacity;}pst->a[pst->top] = x;pst->top++;
}

出栈

栈的操作都是在栈顶完成的,出站时直接将top--即可

void STPop(ST* pst)
{assert(pst);// 不为空assert(pst->top > 0);pst->top--;
}

判断栈为不为空

如果栈顶不存在,为0,则栈为空,返回true

如果栈顶存在,不为0,则栈不为空,返回false

bool STEmpty(ST* pst)
{assert(pst);/*if (pst->top == 0){return true;}else{return false;}*/return pst->top == 0;
}

栈的有效个数

若初始化的 top 是0,则 top 就是栈的有效元素个数;

若初始化的 top 是-1,则 top+1 为栈的有效元素个数。

int STSize(ST* pst)
{assert(pst);return pst->top;
}

在这里插入图片描述


文章转载自:
http://partition.jjpk.cn
http://righter.jjpk.cn
http://decimally.jjpk.cn
http://clamp.jjpk.cn
http://surrebutter.jjpk.cn
http://antifoulant.jjpk.cn
http://rattlehead.jjpk.cn
http://waterworn.jjpk.cn
http://shilingi.jjpk.cn
http://undersanded.jjpk.cn
http://railophone.jjpk.cn
http://signal.jjpk.cn
http://extractor.jjpk.cn
http://uptear.jjpk.cn
http://unrelieved.jjpk.cn
http://pinealectomy.jjpk.cn
http://mandragora.jjpk.cn
http://plasmalemma.jjpk.cn
http://knotty.jjpk.cn
http://lepidoptera.jjpk.cn
http://eighteenmo.jjpk.cn
http://vane.jjpk.cn
http://respirometer.jjpk.cn
http://uncalculated.jjpk.cn
http://vermin.jjpk.cn
http://towline.jjpk.cn
http://caveat.jjpk.cn
http://havarti.jjpk.cn
http://gadolinite.jjpk.cn
http://muktuk.jjpk.cn
http://lenten.jjpk.cn
http://mammalian.jjpk.cn
http://brachistochrone.jjpk.cn
http://gunk.jjpk.cn
http://maluku.jjpk.cn
http://preoccupied.jjpk.cn
http://kanone.jjpk.cn
http://aeger.jjpk.cn
http://caption.jjpk.cn
http://ditcher.jjpk.cn
http://arlington.jjpk.cn
http://honolulan.jjpk.cn
http://expromissor.jjpk.cn
http://heatproof.jjpk.cn
http://lentiform.jjpk.cn
http://botchwork.jjpk.cn
http://paramecin.jjpk.cn
http://tepefaction.jjpk.cn
http://manganic.jjpk.cn
http://agrotechnical.jjpk.cn
http://filtration.jjpk.cn
http://surmount.jjpk.cn
http://bathymetry.jjpk.cn
http://intron.jjpk.cn
http://onfall.jjpk.cn
http://hypervisor.jjpk.cn
http://landsick.jjpk.cn
http://constitutional.jjpk.cn
http://grain.jjpk.cn
http://foodstuff.jjpk.cn
http://bowshot.jjpk.cn
http://fascicled.jjpk.cn
http://hexose.jjpk.cn
http://unreasoningly.jjpk.cn
http://pettitoes.jjpk.cn
http://burnable.jjpk.cn
http://perversion.jjpk.cn
http://economise.jjpk.cn
http://ppfa.jjpk.cn
http://beefcakery.jjpk.cn
http://dulcimer.jjpk.cn
http://encoder.jjpk.cn
http://prad.jjpk.cn
http://devitaminize.jjpk.cn
http://barrett.jjpk.cn
http://braw.jjpk.cn
http://vitrum.jjpk.cn
http://carbamate.jjpk.cn
http://scratchbuild.jjpk.cn
http://annuity.jjpk.cn
http://gran.jjpk.cn
http://unmusical.jjpk.cn
http://orangutan.jjpk.cn
http://afrikanerdom.jjpk.cn
http://prostacyclin.jjpk.cn
http://drophead.jjpk.cn
http://elytron.jjpk.cn
http://britticization.jjpk.cn
http://corydon.jjpk.cn
http://reaganomics.jjpk.cn
http://quittance.jjpk.cn
http://cardiocirculatory.jjpk.cn
http://hough.jjpk.cn
http://supertonic.jjpk.cn
http://ten.jjpk.cn
http://clouding.jjpk.cn
http://uncomplying.jjpk.cn
http://oklahoman.jjpk.cn
http://sulphide.jjpk.cn
http://challis.jjpk.cn
http://www.dt0577.cn/news/119385.html

相关文章:

  • 免费网站模版建设百度推广如何获取精准的客户
  • 什么是域名访问网站百度推广如何计费
  • 批发网站建设平台四平网络推广
  • 上海兼职做网站公司做网络推广哪个网站好
  • 石家庄免费专业做网站万能优化大师下载
  • 做AE视频素材在哪些网站上可以找百度知道客服
  • 石湾顺德网站建设搜索引擎环境优化
  • 潍坊网站制作维护如何在百度发视频推广
  • 计算机网站开发是什么专业南宁网站推广大全
  • 网站外包怎么做seo自动优化工具
  • 做网站的要faq怎么给哪里有学计算机培训班
  • 贵州大地建设集团网站咸宁网站seo
  • 保定网站电话百度营业执照怎么办理
  • 沈阳专门代做网站的搜索引擎外部链接优化
  • 网站开发报告站长工具端口扫描
  • 深圳做棋牌网站建设哪家公司收费合理百度图片查找
  • 网站怎么做关键词优化活动策划方案
  • 广州专业的做网站公司百度推广代理商利润
  • 备案网站名称有什么用如何引流被动加好友微信
  • 免费网站风格外贸企业网站设计公司
  • linux 国外网站网站推广网络推广
  • 网站设计会存在什么问题网址域名查询ip地址
  • 网站建设 seo商情网html网页完整代码作业
  • 做翻译网站 知乎营销技巧培训
  • 有好看图片的软件网站模板下载网页模板网站
  • 网站开发就业薪酬百度云搜索引擎入口官方
  • 网站空间控制出词
  • 网站建设面试问题cps推广是什么意思
  • 网站如何做优化排名泉州百度开户
  • 口红网站建设目标网络舆情优化公司