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

网站首页设计风格有哪些广东省建设厅官方网站多少钱

网站首页设计风格有哪些,广东省建设厅官方网站多少钱,网站建设专家选哪家,免费注册电子邮件地址文章目录 前言概述栈的初始化销毁压栈出栈判断栈为不为空栈的有效个数 前言 栈相对于链表,稍微简单一点,但是栈的难点在于通过栈去理解递归算法。 概述 **栈:**一种特殊的线性表,其只允许在固定的一端进行插入和删除元素操作。…

在这里插入图片描述

文章目录

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

前言

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

概述

**栈:**一种特殊的线性表,其只允许在固定的一端进行插入和删除元素操作。进行数据插入和删除操作的一端称为栈顶,另一端称为栈底。栈中的数据元素遵守 后进先出 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://www.yayakq.cn/news/304632/

相关文章:

  • 搜狗网站优化软件wordpress设计漂亮的页面
  • 网站建设全部流程图wordpress 修改链接失效
  • 用vs做网站如何连接数据库网页设计心得体会1500
  • 软件开发外包是什么意思长沙自动seo
  • seo站外推广业务外包如何在手机做网站
  • 高端房产网站建设有域名怎么免费建站
  • 做it人经常逛的网站软件开发大学
  • 推荐几个手机能看的网站jsp网站建设项目实战 pdf
  • 中国建设银行江西分行网站首页东莞手机网站建设多少钱
  • 电脑记事本做复杂网站设置网站404
  • 网站首页广告wordpress 筛选
  • 太和网站建设公司网站开发建设什么会计科目
  • 上海高端模板建站wordpress取消伪静态
  • 北京网站建设签约虚拟交易网站开发
  • 佛山营销型网站建设外贸网站该怎么做
  • 花都定制型网站建设wordpress5.0新版如何发布文章
  • 中国建设部网站能查叉车证南通建设网站哪家好
  • 培训行业seo整站优化广州微网站开发
  • 做的最好的紫砂网站北京优秀的网站建设公司
  • 个人做金融网站能赚钱吗外国做电子产品网站有哪些
  • 华强北网站建设公司dw制作网页的代码
  • 天津网站备案科技打造巅峰华夏从横推鹰酱开始
  • 手机网站建设官网wordpress插件加密
  • 织梦网站安装视频教程钓鱼网站的危害
  • 静态网页模板免费网站蓝色旅游资讯网站模板
  • 360的网站排名怎么做最好用的搜索引擎
  • 在门户网站上爆光怎么做个人网站网站服务器
  • 网站建设需要干什么推广普通话于1982年写入
  • 微信公众号里怎么做网站金坛做网站的
  • 北京网站制作策划怎样申请微信公众平台账号