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

官方网站建设有限公司天津做网站的网络公司

官方网站建设有限公司,天津做网站的网络公司,免费网页制作软件下载,中国建设银行官网站企业年金文章目录 引言1.栈的基本概念2.选择数组还是链表?3. 定义栈结构4.初始化栈5.压栈操作6.弹栈操作7.查看栈顶和判断栈空9.销毁栈操作10.测试并且打印栈内容栈的实际应用结论 引言 栈是一种基本但强大的数据结构,它在许多算法和系统功能中扮演着关键角色。…

文章目录

  • 引言
  • 1.栈的基本概念
  • 2.选择数组还是链表?
  • 3. 定义栈结构
  • 4.初始化栈
  • 5.压栈操作
  • 6.弹栈操作
  • 7.查看栈顶和判断栈空
  • 9.销毁栈操作
  • 10.测试并且打印栈内容
  • 栈的实际应用
  • 结论

引言

栈是一种基本但强大的数据结构,它在许多算法和系统功能中扮演着关键角色。在这篇文章中,我们将深入探讨如何在实现一个栈,从基本概念到具体的代码实现,再到实际应用场景的探讨。

1.栈的基本概念

在深入代码之前,先简单介绍栈的概念。栈是一个项的有序集合,其中添加(推入)和删除(弹出)项总发生在同一端,称为“栈顶”。他是后进先出的,就好像弹夹里面的子弹一样

在这里插入图片描述
在这里插入图片描述

2.选择数组还是链表?

数组的优点在于实现简单,访问时间快。但其缺点是大小固定,可能会有空间浪费或不足的问题。
链表的优点在于可以动态调整大小,内存利用率高。但其缺点是相对于数组,访问时间可能会稍慢。
我们用数组来实现
在这里插入图片描述


3. 定义栈结构

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<assert.h>
#include<stdlib.h>
#include<stdbool.h>typedef int STDataType;
typedef struct Stack
{STDataType* a;STDataType top; STDataType 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);
int STSize(ST* pst);

4.初始化栈

初始化是栈实现中的第一步。我们需要将栈顶 top 的初始值设为0,以表示栈为空,在这个实现中,栈被定义为包含动态数组、栈顶指针和容量的结构体。初始化函数 STInit 负责设置这些属性的初始状态。

// 初始化栈
void STInit(ST* pst)
{assert(pst);pst->a = NULL;       // 初始时,数组指针为空pst->top = 0;        // 栈顶指针初始为0,表示栈为空pst->capacity = 0;   // 初始容量为0
}

5.压栈操作

在实现压栈操作时,我们要考虑栈可能满的情况。如果栈已满,我们应该阻止进一步的压栈并给出适当的反馈。

// 检查并扩展栈的容量
void SLCheckCapacity(ST* pst)
{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");exit(1); // 如果内存分配失败,则退出程序}pst->a = tmp;pst->capacity = newCapacity;}
}// 向栈中推入一个元素
void STPush(ST* pst, STDataType x)
{assert(pst);SLCheckCapacity(pst); // 检查并扩展容量pst->a[pst->top] = x; // 存放元素pst->top++;           // 栈顶指针增加
}

6.弹栈操作

弹栈时,我们需要确保栈不为空。如果尝试从空栈中弹出元素,应该返回一个错误指示。

// 从栈中弹出一个元素
void STPop(ST* pst)
{assert(pst);assert(pst->top > 0); // 确保栈不为空pst->top--;           // 栈顶指针减少
}

7.查看栈顶和判断栈空

这些操作相对简单,但它们对于栈的有效使用至关重要。

// 获取栈顶元素
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; // 如果栈顶指针为0,则栈为空
}

9.销毁栈操作

在这个静态数组实现中,destroy 函数不是必须的,但是我们使用了动态分配的内存,则需要在此释放内存。

// 销毁栈
void STDestroy(ST* pst)
{assert(pst);free(pst->a);        // 释放栈内部的数组空间pst->a = NULL;       // 将数组指针置为空pst->top = 0;        // 栈顶指针重置为0pst->capacity = 0;   // 容量重置为0
}

10.测试并且打印栈内容

int main()
{ST stack;            // 定义栈变量ST* pst = &stack;    // pst 指向 stackSTInit(pst);         // 初始化栈// 向栈中添加元素STPush(pst, 1);STPush(pst, 2);STPush(pst, 3);STPush(pst, 4);// 打印并弹出栈中的元素while (!STEmpty(pst)){printf("%d ", STTop(pst));STPop(pst);}printf("\n");STDestroy(pst); // 销毁栈return 0;
}

运行结果如下:
在这里插入图片描述


栈的实际应用

栈在计算机科学中有着广泛的应用。从函数调用的内存管理到算法中的临时数据存储,栈的应用无处不在。理解栈如何在这些场景中工作,对于充分利用其潜力至关重要。


结论

栈不仅是一种基本的数据结构,而且是理解更复杂系统和算法的基石。通过在c语言中实现和应用栈,我们不仅能够加深对这一结构的理解,还能够提高我们的编程技巧和问题解决能力。我希望这篇文章能够帮助你更好地理解和实现栈。如果你有任何问题或想分享你的经验,请在评论区留言。

http://www.rdtb.cn/news/1436.html

相关文章:

  • 申请域名后可以做自己的网站吗杭州网站搜索排名
  • 外贸平台哪个网站最好不收费石家庄最新消息今天
  • 网站图文混排怎么存放到数据库里淘宝指数官网
  • 南充做网站略奥网络企业邮箱怎么申请
  • 移动网站开发认证企业查询平台
  • 澄迈网站建设网店运营是做什么的
  • 网站建设初步规划宁波seo外包方案
  • 网站建设网络推广微信网站上首页seo
  • 天津网站推广优化南昌seo排名
  • 天津酒店网站制作seo到底是什么
  • 西维科技做网站怎么样网站关键词排名优化推广软件
  • ip做网站地址三亚百度推广地址
  • 微网站开发 在线商城网络营销的策略包括
  • 微信公众号里怎么做网站seo快速优化技术
  • 手机端模板网站china东莞seo
  • 什么叫网站优化爱站网备案查询
  • 做网站什么主题好做西安百度推广公司
  • dede5.7微电影网站模板青岛seo网站建设公司
  • 沙洋网站开发站长工具查询官网
  • 06年可以做相册视频的网站手机网站
  • 东莞网站建设 烤活鱼sem是什么意思呢
  • 外贸 wordpress英文谷歌自然排名优化
  • wordpress插 件搜索引擎优化特点
  • 死链对网站的影响精准引流客源的方法可靠吗
  • 婚庆网站大全seo是什么意思电商
  • 网站开发项目安全加固的要求seo网络推广经理
  • 广州正佳广场极地海洋世界株洲seo优化推荐
  • html好看的颜色代码郑州网站推广优化公司
  • yahoo搜索引擎提交入口谷歌seo快速排名软件首页
  • 六安网站制作金狮怎么搜索网站