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

数据结构《栈》

数据结构《栈》

  • 1、栈的概念及结构
    • 2、栈的实现
      • 3、练习:

1、栈的概念及结构

栈:一种特殊的线性表,其只允许在固定的一端进行插入和删除元素操作。进行数据插入和删除操作的一端
称为栈顶,另一端称为栈底。栈中的数据元素遵守后进先出LIFO(Last In First Out)的原则。

压栈:栈的插入操作叫做进栈/压栈/入栈,入数据在栈顶
出栈:栈的删除操作叫做出栈。出数据也在栈顶

在这里插入图片描述

2、栈的实现

栈的实现一般可以使用数组或者链表实现,相对而言数组的结构实现更优一些。因为数组在尾上插入数据的
代价比较小。

在这里插入图片描述

进栈、出栈展示:
在这里插入图片描述

实现栈,最好声明与定义分开成俩个文件来处理(头文件,h(介绍接口),实现文件.c(实现接口功能))

1、头文件.h

#include<stdio.h>
#include<assert.h>
#include<stdbool.h>
#include<stdlib.h>typedef int type;
#define N 10;
//静态栈(不常用,所以我们要实现的是动态栈)
typedef struct Stack
{type arr[N];int top;//栈顶
}Stack;//动态栈
typedef struct Stack
{type* a;int top;int capacity;
}sl;// 初始化栈
void Slint(sl* p);
// 入栈
void pushpop(sl* p, type x);
// 出栈
void STpop(sl* p);
// 获取栈顶元素
type STTop(sl* p);
// 获取栈中有效元素个数
int STsize(sl* p); 
// 检测栈是否为空,如果为空返回非零结果,如果不为空返回0 
bool empty(sl* p);
// 销毁栈
void destroy(sl* p);

实现文件.c

void Slint(sl* p)
{assert(p);p->a = NULL;p->capacity = 0;p->top = 0;
}void pushpop(sl* p, type x)
{assert(p);if (p->top == p->capacity){int newcapacity = p->capacity == 0 ? sizeof(type) : 2 * p->capacity;type* new = (type*)realloc(p->a, sizeof(type) * newcapacity);if (new == NULL){perror("realloc fail");return;}p->a = new;p->capacity = newcapacity;}p->a[p->top] = x;p->top++;}void STpop(sl* p)
{assert(p);p->top--;
}type STTop(sl* p)
{assert(p);assert(p->top > 0);return p->a[p->top - 1];
}bool empty(sl* p)
{assert(p);return p->top == 0;
}void destroy(sl* p)
{free(p->a);p->a = NULL;p->capacity = 0;p->top = 0;
}int STsize(sl* p)
{assert(p);return p->top;
}

3、练习:

括号匹配问题

第一步->实现一个栈,在用栈的后进先出特性来匹配括号。
情况1:如果为‘(’、‘[’、‘{’。左括号入栈

情况2:如果为‘)’,‘}’,‘]’右括号与栈顶匹配

//实现一个栈
typedef char type;typedef struct Stack
{type* a;int top;int capacity;
}sl;void Slint(sl* p);void destroy(sl* p);void pushpop(sl* p, type x);void STpop(sl* p);type STTop(sl* p);bool empty(sl* p);int STsize(sl* p);void Slint(sl* p)
{assert(p);p->a = NULL;p->capacity = 0;p->top = 0;
}void pushpop(sl* p, type x)
{assert(p);if (p->top == p->capacity){int newcapacity = p->capacity == 0 ? sizeof(type) : 2 * p->capacity;type* new = (type*)realloc(p->a, sizeof(type) * newcapacity);if (new == NULL){perror("realloc fail");return;}p->a = new;p->capacity = newcapacity;}p->a[p->top] = x;p->top++;}void STpop(sl* p)
{assert(p);p->top--;
}type STTop(sl* p)
{assert(p);assert(p->top > 0);return p->a[p->top - 1];
}bool empty(sl* p)
{assert(p);return p->top == 0;
}void destroy(sl* p)
{free(p->a);p->a = NULL;p->capacity = 0;p->top = 0;
}int STsize(sl* p)
{assert(p);return p->top;
}
//匹配括号
bool isValid(char* s) {sl s3;Slint(&s3);while (*s){if (*s == '(' || *s == '{' || *s == '[')//情况1{pushpop(&s3, *s);}else//情况2{if(empty(&s3)){return false;}char top = STTop(&s3);STpop(&s3);if ((top == '(' && *s != ')') || (top == '[' && *s != ']') || (top == '{' && *s != '}')){return false;}}s++;}bool ret=empty(&s3);//判断栈有没有数据destroy(&s3);return ret ;}
}
http://www.lryc.cn/news/420578.html

相关文章:

  • 说一说mysql的having?和where有什么区别?
  • LeetCode45. 跳跃游戏 II
  • 算法打卡 Day19(二叉树)-平衡二叉树 + 二叉树的所有路径 + 左叶子之和 + 完全二叉树的节点个数
  • 国际以太网专线 (IEPL)/国际专线(IPLC)-全球覆盖,无界沟通
  • 信息安全管理知识体系攻略(至简)
  • HCIE学习笔记:IPV6 地址、ICMP V6、NDP 、DAD (更新补充中)
  • 人工智能】Transformers之Pipeline(九):物体检测(object-detection)
  • [SWPUCTF 2021 新生赛]easy_md5
  • Redis面试题大全
  • 【langchain学习】BM25Retriever和FaissRetriever组合 实现EnsembleRetriever混合检索器的实践
  • 【C语言】预处理详解(上)
  • uni-app内置组件(基本内容,表单组件)()二
  • linux搭建redis超详细
  • Flink-DataWorks第二部分:数据集成(第58天)
  • 4个从阿里毕业的P7打工人,当起了包子铺的老板
  • javaweb_07:分层解耦
  • 调用 Python 开源库,获取油管英文视频的手动或自动英文srt字幕,以及自动中文简体翻译srt字幕
  • UDP协议实现通信与数据传输(创建客户端和服务器)
  • 【红黑树】
  • 排序算法——简单选择排序
  • OpenAI API推出结构化输出功能
  • Python 异步编程:Sqlalchemy 异步实现方式
  • 父类引用指向子类对象
  • 分享一个基于Spring Boot的面向社区的智能化健康管理系统的设计与实现(源码、调试、LW、开题、PPT)
  • 【扒代码】reduction参数是什么
  • Python,Spire.Doc模块,处理word、docx文件,极致丝滑
  • redis的安装与命令
  • 【C++】特殊类设计类型转换
  • 为git 命令行 设置代理环境变量
  • 自定义linux某些常见配置