C语言数据结构(5)--顺序栈

简介: 本文目录1. 背景2. 顺序栈3. 栈的操作4. 顺序栈的代码实现

1. 背景

栈应该是第一次出现一个很专业名词的数据结构了吧,但是栈依然是一个非常简单一维结构。


之所以称之为栈,就是因为栈的特点是后进先出,就像一个货栈,先放进去东西总是放在里面,后放进去的东西放到门口,所以往外拿出来的时候,就先拿出来门口的。


2. 顺序栈

我们把线性表看为从上到下的一个一维结构,不管是往线性表里添加元素还是取出元素,都是在上部(顶部)操作,不就是后进先出了吗。


所以栈其实就是在一维线性表顶部(最后面)进行添加或者取出的集合。


栈可以使用数组或者链表作为存储结构,当使用数组时为顺序栈,使用链表时为链栈。


3. 栈的操作

入栈,将一个元素放入栈中

出栈,将栈顶元素拿出来

其他操作实际上都是以这几个操作为基础实现的。


4. 顺序栈的代码实现

/*
* 顺序栈的实现
* 作者:熊猫大大
* 时间:2019-09-28
*/
#include<stdio.h>
#define STACK_LENGTH 10
//定义结构体保存栈信息
struct Stack
{
  //栈元素
  int element[STACK_LENGTH];
  //栈顶位置 top==0表示元素为空 top==x表示有x个元素且栈顶元素在element[x-1]处
  int top;
};
//展示栈内所有元素(方便测试),从栈顶到栈底的顺序展示即可
void printStack(struct Stack *p)
{
  int i;
  printf("==================当前栈内元素如下\n");
  for (i = p->top - 1; i >= 0; i--)
  {
    printf("%d ", p->element[i]);
  }
  printf("\n==================\n");
}
//入栈
int stackIn(struct Stack *p, int num)
{
  if (p->top>STACK_LENGTH - 1)//栈满了
    return 0;//入栈失败
  p->element[p->top] = num;
  p->top++;
  return 1;//入栈成功
}
//出栈,以返回值的形式提供出栈元素的值
int stackOut(struct Stack *p, int *result)
{
  if (p->top <= 0)//空栈
    return 0;
  //取栈顶元素
  *result = p->element[p->top - 1];
  //栈顶元素出栈
  p->top--;
  return 1;
}
//入口
int main()
{
  //初始化
  struct Stack stack;
  stack.top = 0;
  printStack(&stack);
  //入栈
  stackIn(&stack, 1);
  stackIn(&stack, 2);
  stackIn(&stack, 3);
  stackIn(&stack, 7);
  stackIn(&stack, 8);
  stackIn(&stack, 9);
  //输出
  printStack(&stack);
  //出栈
  int result;
  stackOut(&stack, &result);
  printf("OUT:%d\n", result);
  stackOut(&stack, &result);
  printf("OUT:%d\n", result);
  stackOut(&stack, &result);
  printf("OUT:%d\n", result);
  printStack(&stack);
  stackOut(&stack, &result);
  printf("OUT:%d\n", result);
  stackOut(&stack, &result);
  printf("OUT:%d\n", result);
  stackOut(&stack, &result);
  printf("OUT:%d\n", result);
  printStack(&stack);
  return 1;
}
相关文章
|
14天前
|
C语言
【数据结构】栈和队列(c语言实现)(附源码)
本文介绍了栈和队列两种数据结构。栈是一种只能在一端进行插入和删除操作的线性表,遵循“先进后出”原则;队列则在一端插入、另一端删除,遵循“先进先出”原则。文章详细讲解了栈和队列的结构定义、方法声明及实现,并提供了完整的代码示例。栈和队列在实际应用中非常广泛,如二叉树的层序遍历和快速排序的非递归实现等。
90 9
|
5天前
|
存储 算法
非递归实现后序遍历时,如何避免栈溢出?
后序遍历的递归实现和非递归实现各有优缺点,在实际应用中需要根据具体的问题需求、二叉树的特点以及性能和空间的限制等因素来选择合适的实现方式。
14 1
|
8天前
|
存储 算法 Java
数据结构的栈
栈作为一种简单而高效的数据结构,在计算机科学和软件开发中有着广泛的应用。通过合理地使用栈,可以有效地解决许多与数据存储和操作相关的问题。
|
13天前
|
存储 搜索推荐 算法
【数据结构】树型结构详解 + 堆的实现(c语言)(附源码)
本文介绍了树和二叉树的基本概念及结构,重点讲解了堆这一重要的数据结构。堆是一种特殊的完全二叉树,常用于实现优先队列和高效的排序算法(如堆排序)。文章详细描述了堆的性质、存储方式及其实现方法,包括插入、删除和取堆顶数据等操作的具体实现。通过这些内容,读者可以全面了解堆的原理和应用。
56 16
|
13天前
|
C语言
【数据结构】二叉树(c语言)(附源码)
本文介绍了如何使用链式结构实现二叉树的基本功能,包括前序、中序、后序和层序遍历,统计节点个数和树的高度,查找节点,判断是否为完全二叉树,以及销毁二叉树。通过手动创建一棵二叉树,详细讲解了每个功能的实现方法和代码示例,帮助读者深入理解递归和数据结构的应用。
62 8
|
11天前
|
存储 JavaScript 前端开发
执行上下文和执行栈
执行上下文是JavaScript运行代码时的环境,每个执行上下文都有自己的变量对象、作用域链和this值。执行栈用于管理函数调用,每当调用一个函数,就会在栈中添加一个新的执行上下文。
|
13天前
|
存储
系统调用处理程序在内核栈中保存了哪些上下文信息?
【10月更文挑战第29天】系统调用处理程序在内核栈中保存的这些上下文信息对于保证系统调用的正确执行和用户程序的正常恢复至关重要。通过准确地保存和恢复这些信息,操作系统能够实现用户模式和内核模式之间的无缝切换,为用户程序提供稳定、可靠的系统服务。
40 4
|
16天前
|
存储 C语言
【数据结构】手把手教你单链表(c语言)(附源码)
本文介绍了单链表的基本概念、结构定义及其实现方法。单链表是一种内存地址不连续但逻辑顺序连续的数据结构,每个节点包含数据域和指针域。文章详细讲解了单链表的常见操作,如头插、尾插、头删、尾删、查找、指定位置插入和删除等,并提供了完整的C语言代码示例。通过学习单链表,可以更好地理解数据结构的底层逻辑,提高编程能力。
44 4
|
16天前
|
C语言
【数据结构】双向带头循环链表(c语言)(附源码)
本文介绍了双向带头循环链表的概念和实现。双向带头循环链表具有三个关键点:双向、带头和循环。与单链表相比,它的头插、尾插、头删、尾删等操作的时间复杂度均为O(1),提高了运行效率。文章详细讲解了链表的结构定义、方法声明和实现,包括创建新节点、初始化、打印、判断是否为空、插入和删除节点等操作。最后提供了完整的代码示例。
37 0
|
存储 缓存 C语言
数据结构——双链表(C语言)
数据结构——双链表(C语言)