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

信用泰安网站广州哪个公司做网站

信用泰安网站,广州哪个公司做网站,口碑营销的名词解释,动漫做a视频网站有哪些目录 前言 1. 栈 1.1 栈的概念 1.2 栈的结构 2. 栈的实现 2.1 栈的初始化 2.2 入栈 2.3 出栈 2.4 读取栈顶元素 2.5 判断栈空 2.6栈的销毁 3. 栈完整源代码 Stack.h Stack.c #x1f388;个人主页#xff1a;库库的里昂 #x1f390;C/C领域新星创作者 …目录 前言 1. 栈 1.1 栈的概念 1.2 栈的结构 2. 栈的实现 2.1 栈的初始化 2.2 入栈 2.3 出栈  2.4 读取栈顶元素 2.5 判断栈空 2.6栈的销毁 3. 栈完整源代码 Stack.h Stack.c 个人主页库库的里昂 C/C领域新星创作者 欢迎 点赞✍评论⭐收藏✨收录专栏数据结构与算法希望作者的文章能对你有所帮助有不足的地方请在评论区留言指正大家一起学习交流 前言 在前几期的学习中我们认识了顺序表和链表这两种线性表而在本期学习中我们将会认识别的线性表。跟随我们的脚本看看栈和队列有怎样的特点。 1. 栈 1.1 栈的概念 栈一种特殊的线性表其只允许在固定的一端进行插入和删除元素操作。进行数据插入和删除操作的一端称为栈顶另一端称为栈底。栈中的数据元素遵守后进先出LIFOLast In First Out的原则。 压栈栈的插入操作叫做进栈/压栈/入栈入数据在栈顶。出栈栈的删除操作叫做出栈。出数据也在栈顶。 1.2 栈的结构 2. 栈的实现 栈的实现一般可以使用数组或者链表实现相对而言数组的结构实现更优一些。因为数组在尾上插入数据的代价比较小。 2.1 栈的初始化 我们将结构体的所有元素都初始化为0。这里与我们在顺序表中的初始化不同在顺序表中我们在初始化时就开辟了空间下面我们会介绍另一种方式。 void STInit(ST* pst) {assert(pst);pst-a NULL;pst-capacity 0;pst-top 0; } 2.2 入栈 在进栈时可能遇到容量为零所以我们使用一个条件判断来确定容量。因为top为0所以它表示的是下一个元素的下标要先赋值再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 calloc(pst-a, sizeof(STDataType) * newcapacity);if (tmp NULL){perror(calloc fail);return;}pst-a tmp;pst-capacity newcapacity;}pst-a[pst-top] x;pst-top; } malloc 和 realloc 开辟空间的区别就是 realloc 要传递一个指针而当我们给 realloc 传递一个空指针那么它的功能就和 malloc 相同。  2.3 出栈  出栈只需要将 top --就访问不到这个元素了。在出栈时我们要判断栈中是否还有元素。 void STPop(ST* pst) {assert(pst);assert(pst-top 0);pst-top--; } 2.4 读取栈顶元素 栈顶元素就是我们插入的最后一个元素。由于top表示的是下一个元素的下标所以读取栈顶元素是top要减1。 STDataType STTop(ST* pst) {assert(pst);assert(pst-top 0);return pst-a[pst-top - 1]; }2.5 判断栈空 bool STEmpty(ST* pst) {assert(pst);return pst-top 0; } 2.6栈的销毁 这里使用的内存是动态开辟的因此在我们使用完后要及时释放掉内存否则会造成内存泄漏。 void STDestroy(ST* pst) {assert(pst);free(pst-a);pst-a NULL;pst-top 0;pst-capacity 0; } 3. 栈完整源代码 Stack.h #includestdio.h #includeassert.h #includestdlib.h #includestdbool.htypedef int STDataType;typedef struct Stack {STDataType* a;int top; // 标识栈顶位置的int capacity; }ST;void STInit(ST* pst);//初始化void STDestroy(ST* pst);//销毁void STPush(ST* pst, STDataType x);//入栈void STPop(ST* pst);//出栈STDataType STTop(ST* pst);//读取栈顶元素bool STEmpty(ST* pst);//判断栈空 Stack.c #includeStack.hvoid STInit(ST* pst) {assert(pst);pst-a NULL;pst-capacity 0;pst-top 0; }void STDestroy(ST* pst) {assert(pst);free(pst-a);pst-a NULL;pst-top 0;pst-capacity 0; }void STPush(ST* pst, STDataType x) {assert(pst);if (pst-top pst-capacity){int newcapacity pst-capacity 0 ? 4 : pst-capacity * 2;STDataType* tmp calloc(pst-a, sizeof(STDataType) * newcapacity);if (tmp NULL){perror(calloc fail);return;}pst-a tmp;pst-capacity newcapacity;}pst-a[pst-top] x;pst-top; }void STPop(ST* pst) {assert(pst);assert(pst-top 0);pst-top--; }STDataType STTop(ST* pst) {assert(pst);assert(pst-top 0);return pst-a[pst-top - 1]; }bool STEmpty(ST* pst) {assert(pst);return pst-top 0; } 本次的内容到这里就结束啦。希望大家阅读完可以有所收获同时也感谢各位读者三连支持。文章有问题可以在评论区留言博主一定认真认真修改以后写出更好的文章。你们的支持就是博主最大的动力。
http://www.hkea.cn/news/14328230/

相关文章:

  • 朱晓宇 大庆 seo 网站建设 北京怎么理解网站开发
  • 济南高新区建设局网站网站备案进度查询
  • 大棚网站怎么做杭州网站忧化
  • 网站开发流程甘特图海外广告投放渠道营销
  • 商务网站建设期末考试提高工作效率的句子
  • 网站建设 问答资海网络一年做多少网站
  • php网站框架哪些网站做平面设计素材
  • 免费建站自助建站安全网络公司排名
  • 网站首页图片尺寸自助网站建设程序
  • 一万并发量的视频网站建设网站域名怎么过户
  • 个人可以做医疗信息网站吗没电脑可以建网站吗
  • 如何提升网站流量软件开发流程图用啥画
  • 厦门专业网站营销搜索关键词排名
  • 重庆多功能网站建设asp.net网站开发百科
  • 哪个网站可以用来做读书笔记做百度推广会送网站吗
  • 深圳网站制作哪家专业wordpress换回原版编辑器
  • 手机网站收录2013年以前pc网站建设
  • 网站建设声明函创业网站怎么做的
  • 陕icp网站建设建设厅的证在哪里查询
  • 建设产品信息网站生鲜网站策划
  • 网站设计论文的摘要wordpress 锚点定位
  • 厦门百度整站优化服务门户网站建设不断
  • 网站建设岗位的任职资格哪里买域名便宜
  • 网站建设公司果动c如何做中国古城的网站
  • 湘潭网站设计外包公司wordpress简约文字主题
  • 做杂志的网站蔬菜水果网站建设
  • 网站互动方式网站建设公司厦门有哪些
  • 用asp.net做网站hhvm wordpress
  • flash网站模板下载珠海网络营销网站建设
  • 购物网站毕业设计论文wordpress 关键词