【LeetCode刷题指南】--有效的括号

🔥个人主页:@草莓熊Lotso

🎬作者简介:C++研发方向学习者

📖个人专栏: 《C语言》 《数据结构与算法》《C语言刷题集》《Leetcode刷题指南》

⭐️人生格言:生活是默默的坚持,毅力是永久的享受。  

前言:随着编程相关知识点的学习,我们LeetCode的刷题也不能落下。在前面我们也接触到了洛谷和牛客这两个刷题网站,但是博主一直都在推荐大家使用力扣,是因为力扣的判题严谨且大部分都是接口型题目,与面试中的笔试题也更加贴合。那么还是老样子,博主会为大家提供我自己的思路和代码,但是算法题的解法肯定不止一个,欢迎大家一起交流和讨论。


目录

有效的括号

解题过程:

代码演示: 


有效的括号

题目链接:20. 有效的括号 - 力扣(LeetCode)

题目描述:

题目示例: 

 思路:借助数据结构-栈,遍历字符串,左括号入栈,右括号取栈顶元素进行比较,看是否匹配

解题过程:

1.遍历字符串,左括号就入栈,右括号就取栈顶元素

2.前提是不为空才能取,如果为空证明前面没有左括号直接销毁返回false

3.如果不为空,取栈顶元素进行匹配,出现匹配不成功的销毁后返回false

4.如果本次匹配成功,出栈,继续遍历

5.遍历完后进行判空,如果栈为空证明全部匹配上了,返回true,如果不为空则返回false

复杂度:

  • 时间复杂度: O(n)
  • 空间复杂度: O(∗)

代码演示: 

typedef char STDataType;
typedef struct Stack
{STDataType* arr;int top;int capacity;
}ST;//初始化
void STInit(ST* ps)
{ps->arr = NULL;ps->top = ps->capacity = 0;
}//销毁
void STDestory(ST* ps)
{if (ps->arr)free(ps->arr);ps->top = 0;ps->capacity = 0;
}//入栈
void STPush(ST* ps, STDataType x)
{assert(ps);//检查空间//空间不够就增容if (ps->top == ps->capacity){int newcapacity = ps->capacity == 0 ? 4 : 2 * ps->capacity;STDataType* tmp = (STDataType*)realloc(ps->arr, newcapacity * sizeof(STDataType));if (tmp == NULL){perror("realloc fail!");exit(1);}ps->arr = tmp;ps->capacity = newcapacity;}//空间足够ps->arr[ps->top++] = x;
}//出栈
void STPop(ST*ps)
{//ps->top--;
}//取栈顶元素
STDataType STTop(ST* ps)
{return 	ps->arr[ps->top - 1];;
}//判空
bool STEmpty(ST* ps)
{assert(ps);return ps->top == 0;
}//求栈中有效数据个数
int STSize(ST* ps)
{assert(ps);return ps->top;
}//----------------------以上是栈结构常用接口--------------------------------
bool isValid(char* s) {ST st;STInit(&st);char*pi=s;while(*pi!='\0'){if(*pi=='('||*pi=='['||*pi=='{'){STPush(&st,*pi);}else{//右括号取栈顶元素进行匹配//栈不为空才能取if(STEmpty(&st)){STDestory(&st);return false;}char top=STTop(&st);if((top=='('&&*pi!=')')||(top=='['&&*pi!=']')||(top=='{'&&*pi!='}')){STDestory(&st);return false;}//本次匹配就出栈STPop(&st);}pi++;}//为空有效,非空无效bool ret=STEmpty(&st)?true:false;STDestory(&st);return ret;
}

这里用到了栈的结构,大家如果使用C语言写的话可以把我们之前自己实现的栈直接拷贝上去   


 往期回顾:

【数据结构初阶】--双向链表(一)

​​​​​​【数据结构初阶】--双向链表(二)

【LeetCode刷题指南】--随机链表的复制

结语:本篇文章就到此结束了,《LetetCode刷题指南》中的题目比起之间的C语言刷题集中的题目,肯定会更加复杂一些。而且题目形式也不一样,大家需要注意一下。如果文章对你有帮助的话,欢迎评论,点赞,收藏加关注,感谢大家的支持

    本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/2657.html

    如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

    相关文章

    【PyTorch】图像多分类项目

    【PyTorch】图像二分类项目 【PyTorch】图像二分类项目-部署 【PyTorch】图像多分类项目 【PyTorch】图像多分类项目部署 多类图像分类的目标是为一组固定类别中的图像分配标签。 目录 加载和处理数据 搭建模型 定义损失函数 定义优化器 训练和迁移学习 用随机权重进行训…

    详谈OSI七层模型和TCP/IP四层模型以及tcp与udp为什么是4层,http与https为什么是7层

    一、网络模型:OSI七层 vs TCP/IP四层OSI七层模型 (理论参考模型):目的:提供一个标准化的理论框架,用于理解网络通信过程和各层的功能划分,促进不同厂商设备的互操作性。它是一个理想化的模型。分层 (从下到上):物理层:…

    自然语言处理技术应用领域深度解析:从理论到实践的全面探索

    1. 引言:自然语言处理的技术革命与应用前景 自然语言处理(Natural Language Processing,NLP)作为人工智能领域的核心分支,正在以前所未有的速度改变着我们的数字化生活。从最初的规则基础系统到如今基于深度学习的大语言模型,NLP技术经历了从理论探索到实际应用的深刻变…

    Qt:qRegisterMetaType函数使用介绍

    简介 在Qt中,qRegisterMetaType是一个用于向元对象系统注册自定义类型的函数。这对于需要在信号和槽中使用自定义类型(包括模板类如 std::shared_ptr)或用于排队连接(Queued Connection)非常重要。 作用: ​​使类型可用于信号与槽机制​​:特别是当信号和槽连接类型为…

    《使用Qt Quick从零构建AI螺丝瑕疵检测系统》——5. 集成OpenCV:让程序拥有“视力”

    目录一、概述1.1 背景介绍:赋予应用“视力”1.2 学习目标二、集成OpenCV2.1 安装OpenCV2.2 在Qt项目中配置CMake三、项目数据集介绍与准备四、图像的桥梁:ImageProvider与格式转换五、加载、转换并显示图像六、总结与展望一、概述 1.1 背景介绍&#xf…

    Grafana

    官网:https://grafana.com/zh-cn/grafana/ 文章目录GrafanaGrafana Grafana 是一个非常强大且流行的开源数据可视化和监控平台。公司能有 Grafana 平台来监控各种程序状态,是运维、开发和业务洞察的利器。 数据可视化: 这是 Grafana 的看家本…

    go语言基础教程:【1】基础语法:变量

    【1】基础语法 1. 注释 package mainimport "fmt"func main() {// 单行注释// 这是一个终端打印文本的功能/*这是一个多行注释这是一个多行注释这是一个多行注释*/fmt.Println("hello world!") }2. 变量 (1)变量的基本使用 package …

    AI大模型各类概念扫盲

    以下内容整理自AI,进行一个概念扫盲:Prompt(提示词) Prompt是用户提供给AI模型的指令或问题,用于引导模型生成特定输出。良好的Prompt设计能显著提升模型的任务理解能力和响应质量,例如通过结构化提示&…

    【NLP舆情分析】基于python微博舆情分析可视化系统(flask+pandas+echarts) 视频教程 - 主页-评论用户名词云图实现

    大家好,我是java1234_小锋老师,最近写了一套【NLP舆情分析】基于python微博舆情分析可视化系统(flaskpandasecharts)视频教程,持续更新中,计划月底更新完,感谢支持。今天讲解主页-评论用户名词云图实现 视频在线地址&…

    Springmvc的自动解管理

    中央转发器&#xff08;DispatcherServlet&#xff09;控制器视图解析器静态资源访问消息转换器格式化静态资源管理一、中央转发器Xml无需配置<servlet><servlet-name>chapter2</servlet-name><servlet-class>org.springframework.web.servlet.Dispatc…

    JavaScript中this的5大核心规则详解

    在 JavaScript 中&#xff0c;this 是一个特殊关键字&#xff0c;其值取决于函数的 调用方式 而非定义位置。它的行为遵循一套明确的规则&#xff0c;以下是核心规则和示例&#xff1a;1. 默认绑定&#xff08;独立函数调用&#xff09; 当函数独立调用时&#xff08;不作为方法…

    深度分析Java内存回收机制

    内存回收机制是Java区别于C/C等语言的核心特性之一&#xff0c;也是Java开发者理解程序性能、解决内存相关问题&#xff08;如内存泄漏、OOM&#xff09;的关键。 核心目标&#xff1a; 自动回收程序中不再使用的对象所占用的内存&#xff0c;防止内存耗尽&#xff0c;同时尽量…