首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

数据结构——栈(C语言版)

前言: 在学习完数据结构顺序表和链表之后,其实我们就可以做很多事情了,后面的栈和队列,其实就是对前面的顺序表和链表的灵活运用,今天我们就来学习一下栈的原理和应用。...准备工作:本人习惯将文件放在test.c、SeqList.c、SeqList.h三个文件中来实现,其中test.c用来放主函数,SeqList.c用来放调用的函数,SeqList.h用来放头文件和函数声明...bool STEmpty(ST* pst); //找栈顶元素 STDataType STTop(ST* pst); //栈中元素个数 STDataType STSize(ST* pst); test.c...("%d ", STTop(&st)); STPop(&st); } STDestroy(&st); } int main() { test(); return 0; } SeqList.c...pst->capacity; } 总结 总之,其实栈就是对顺序表的应用,熟练栈和队列,对我们巩固顺序表和链表帮助很大,当然,栈在一些场景下很实用,后面我会出一个专门的习题讲解篇章,讲数据结构的一些经典题型

8010

【数据结构(C语言版)系列二】 栈

栈和队列是两种重要的线性结构。从数据结构角度看,栈和队列也是线性表,但它们是操作受限的线性表,因此,可称为限定性的数据结构。但从数据类型角度看,它们是和线性表大不相同的两类重要的抽象数据类型。...顺序栈,即栈的顺序存储结构是利用一组地址连续的存储单元依次存放自栈底到栈订的数据元素,同时附设指针top指示栈顶元素在顺序栈中的位置。...通常的习惯做法是以top=0表示空栈,但与C语言中数组的下标从0开始冲突。...附几个栈的应用举例: 3-2-进制转换-栈和队列-第3章-《数据结构》课本源码-严蔚敏吴伟民版 3-3-行编辑程序-栈和队列-第3章-《数据结构》课本源码-严蔚敏吴伟民版 3-4-迷宫寻路-栈和队列-第...3章-《数据结构》课本源码-严蔚敏吴伟民版 3-5-表达式求值-栈和队列-第3章-《数据结构》课本源码-严蔚敏吴伟民版 3-6-汉诺塔(Hanoi Tower)问题-栈和队列-第3章-《数据结构》课本源码

1.4K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    C语言数据结构与算法--简单实现栈的出栈与入栈

    (三)栈的链式表示时元素压入、弹出 算法实现思路 1.栈的线性链表的压入算法 压入算法过程为:定义新的结点 p、修改新结 点的指针(指向原栈顶结点 top)、给新结点 p 赋 值为 x、...p->top = -1; // 初始化top为-1,表示栈为空 return p; } // 入栈函数,在p栈尾插入a void StackInput(stack* p, int...\n"); return 1; // 如果创建栈失败,返回1 } printf("请输入入栈个数:"); scanf("%d", &n); // 读取入栈的元素个数...printf("入栈后:\n"); Print_function(p); // 打印当前栈的状态 } printf("请输入出栈个数:");...\n"); return 1; // 如果创建栈失败,返回1 } printf("请输入入栈个数:"); scanf("%d", &n); // 读取入栈的元素个数

    14210

    用队列实现栈(C语言版本)

    个人主页: :✨✨✨初阶牛✨✨✨ 强烈推荐优质专栏: C++的世界(持续更新中) 推荐专栏1: C语言初阶 推荐专栏2: C语言进阶 个人信条: 知行合一 前言 在做这个题目之前,应当熟悉栈和队列这两种数据结构....栈和队列都是常见的数据结构,它们是基于数组或链表实现的线性数据结构。...栈(Stack): 栈是一种后进先出(Last-In-First-Out,LIFO)的数据结构,只允许在栈顶进行插入和删除操作。...栈的基本操作包括入栈(push)、出栈(pop)、查看栈顶元素(top)和判断栈是否为空(empty)。 应用场景:实现程序调用的函数堆栈、表达式求值、括号匹配检验等。...) 对于入栈操作,谁是空队列,就往这个队列中正常压数据,模拟压栈的过程.

    17730

    数据结构——队列(C语言版)

    前言: 在学习完数据结构顺序表和链表之后,其实我们就可以做很多事情了,后面的栈和队列,其实就是对前面的顺序表和链表的灵活运用,今天我们就来学习一下队列的原理和应用。...准备工作:本人习惯将文件放在test.c、SeqList.c、SeqList.h三个文件中来实现,其中test.c用来放主函数,SeqList.c用来放调用的函数,SeqList.h用来放头文件和函数声明...pq->ptail->next = newnode; pq->ptail = newnode; } pq->size++; } 用单链表插入数据必须要考虑头部为空和不为空两种情况 4、删除 栈和队列都有一个特点就是...bool QueueEmpty(Queue* pq) { assert(pq); return pq->phead == NULL; } 运行后结果: 总结 总之,其实队列就是对链表的应用,熟练栈和队列...,对我们巩固顺序表和链表帮助很大,当然,队列在一些场景下很实用,后面我会出一个专门的习题讲解篇章,讲数据结构的一些经典题型,感兴趣的可以点赞关注一下 创作不易,还请各位大佬点赞支持一下!!!

    7510

    数据结构——顺序表(C语言版)

    顺序表是数据结构中最基本的一种线性表,它以一段连续的存储空间来存储数据元素,元素之间的顺序由它们在内存中的位置来决定。在C语言中,我们通常使用数组来实现顺序表。...的位置为: %d\\n", index); } else { printf("元素30不存在\\n"); } return 0; } 通过以上实现,我们可以在C语言中创建...顺序表的简单实现不仅有助于理解数据结构的基本概念,还可以为解决实际问题提供基础。...顺序表作为线性表的开头部分,对于我们后续学习数据结构中还是很重要的,需要我们把它学好,本篇文章也只是点了一下知识点并给出少许例子,更多的知识还需要我们自己去探索学习!

    28310

    【数据结构(C语言版)系列三】 队列

    双端队列 除了栈和队列之外,还有一种限定性数据结构是双端队列:限定插入和删除操作在表的两端进行的线性表。两端分别称为端点1和端点2,也可像栈一样,可用一个铁道转轨网络来比喻双端队列。...而如果限定双端队列从某个端点插入的元素只能从该端点删除,则该双端队列就蜕变为两个栈底相邻接的栈了。 ? 尽管双端队列看起来似乎比栈和队列更灵活,但实际上在应用程序中远不及栈和队列有用。...然而此时又不宜如顺序栈那样,进行存储再分配扩大数组空间,因为队列的实际可用空间并为占满。因此提出了循环队列的概念。 ?...在C语言中,不能用动态分配的一维数组来实现循环队列,如果用户的应用程序中设有循环队列,则必须为它设定一个最大队列长度,若用户无法预估长度,则宜采用链队列。 ?...附:3-9-模拟银行排队过程-栈和队列-第3章-《数据结构》课本源码-严蔚敏吴伟民版

    1.2K21

    数据结构_顺序栈(C++

    数据结构_顺序栈(C++实现 前言:此类笔记仅用于个人复习,内容主要在于记录和体现个人理解,详细还请结合bite课件、录播、板书和代码。...两者除了在结构上不同,还有一点不同就是数组栈是栈底在前面(首结点),栈顶在后面(尾结点),通过尾插尾删入栈出栈,链式栈是栈顶在前面,栈底在后面,通过头插头删入栈出栈,与数组栈方向相反。...,在临时栈中排成栈底最小,栈顶最大 主栈栈顶大于等于临时栈顶,直接出主栈入临时栈 小于临时栈顶,主栈栈顶先出栈赋值给k,临时栈逐个出栈到主栈,直到临时栈顶小于k,k入临时栈,在将之前放到主栈的临时栈元素放回临时栈...临时栈为空,主栈栈顶进临时栈;主栈栈顶是小于0的,进临时栈;主栈栈顶大于0,临时栈小于零,判断他俩的和,大于零说明主栈栈顶绝对值大,保留主栈栈顶,临时栈顶出栈,否则反之,如果和等0,则两边都出栈。...最后主栈空了就临时栈出栈到主栈 因为结果保存在了栈里,输出的时候顺序是反的,不过只要再写一个逆置的函数就可以,比如把栈元素放到队列了,再出队列到栈就可以了 现有一个柱状图中,其中每个矩形柱子皆为相邻,

    46230

    栈的压入、弹出序列 栈的压入、弹出序列

    题目描述 输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否为该栈的弹出顺序。假设压入栈的所有数字均不相等。...例如序列1,2,3,4,5是某栈的压入顺序,序列4,5,3,2,1是该压栈序列对应的一个弹出序列,但4,3,5,1,2就不可能是该压栈序列的弹出序列。...(注意:这两个序列的长度是相等的) 解题思路 模拟堆栈操作的过程,将原数列依次压栈,把栈顶元素与所给出栈队列相比,如果相同则出栈,如果不同则继续压栈,直到原数列中所有数字压栈完毕。...最后,检测栈中是否为空,若空,说明出栈队列可由原数列进行栈操作得到。否则,说明出栈队列不能由原数列进行栈操作得到。

    56320
    领券