leetcode:20. 有效的括号

一、题目:

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

 

函数原型:bool isValid(char* s)

二、思路:

利用栈来解这道题会方便许多:

遍历字符串s,当遇到左括号就将其压入栈中;遇到右括号首先判断栈是否为空,如果为空说明左右括号数量不匹配返回false,再判断它与左括号是否匹配,如果不匹配返回false,如果匹配则将栈顶元素出栈。全部遍历完成后,如果栈不为空,说明左右括号数量不匹配,返回false,如果栈为空则返回true。

三、代码:

//顺序栈的结构定义
typedef char STDataType;typedef struct Stack {STDataType* a;int top;int capacity;
}ST;//顺序栈的初始化
void STInit(ST* pst)
{assert(pst);pst->a = NULL;pst->top = 0;//top指针指向栈顶元素的下一位pst->capacity = 0;//顺序栈的容量
}//顺序栈的打印
void STPrint(ST pst)
{for (int i = 0; i < pst.top; i++){printf("%d ", pst.a[i]);}printf("\n");
}//顺序栈的入栈
void STPush(ST* pst, STDataType x)
{assert(pst);//检查扩容if (pst->top == pst->capacity){int newcapacity = pst->capacity == 0 ? 4 : 2 * pst->capacity;STDataType* p = (STDataType*)realloc(pst->a, newcapacity * sizeof(STDataType));if (p == NULL){perror("realloc fail");exit(-1);}else{pst->a = p;pst->capacity = newcapacity;}}pst->a[pst->top++] = x;
}//顺序栈出栈
void STPop(ST* pst)
{assert(pst);assert(pst->top > 0);pst->top--;
}//求顺序栈栈顶元素
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;
}//顺序栈销毁
void STDestroy(ST* pst)
{assert(pst);if (pst->a != NULL){free(pst->a);pst->a = NULL;pst->top = 0;pst->capacity = 0;}
}bool isValid(char* s) {//定义顺序栈ST st;//初始化顺序栈STInit(&st);int len=strlen(s);for(int i=0;i<len;i++){if(s[i]=='('||s[i]=='{'||s[i]=='['){STPush(&st,s[i]);}else if(s[i]==')'||s[i]=='}'||s[i]==']'){if(STEmpty(&st))return false;else{if((STTop(&st)=='('&&s[i]!=')')||(STTop(&st)=='{'&&s[i]!='}')||(STTop(&st)=='['&&s[i]!=']'))return false;STPop(&st);    }}}if(!STEmpty(&st))return false;elsereturn true;
}

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

局域网无法上网主机通过TinyProxy代理主机访问公网Internet

1.代理主机搭建: 系统:ubuntu 网卡:2个 运行于 VMWare上 第一个网卡用于NAT 第二个网卡用于私有网络 两个IP如下: 192.168.31.243为NAT可访问Internet 192.168.144.141属于私有网络,用于访问局域网 安装tinyproxy sudo apt install tinyproxy 查看服务状态

二重积分一般计算步骤

文章目录 二重积分计算的一般步骤分析积分区域草图积分区域对称性区域分割 可以简化计算的两类情况&#x1f47a;利用对称性和奇偶性计算双轴对称变量的对称性轮换对称计算 选择合适的坐标系直角坐标系先 y y y后 x x x先 x x x后y 极坐标系 确定积分区间积分次序积分限 应用例…

webAPI serial——串口连称

重点 关闭正在读的串口 借鉴文章:webapi串口 async closeport() {this.$emit("changeSerialStatus", false);//这里要注意&#xff0c;一定要关闭读取this.status false;//取消后&#xff0c;done会变成true&#xff0c;会执行reader.releaseLock();this.reader.c…

AcWing91.最短 Hamilton 路径

题目 给定一张 n n n 个点的带权无向图&#xff0c;点从 0∼ n − 1 n−1 n−1 标号&#xff0c;求起点 0 到终点 n − 1 n−1 n−1 的最短 Hamilton 路径。 Hamilton 路径的定义是从 0 到 n − 1 n−1 n−1 不重不漏地经过每个点恰好一次。 输入格式 第一行输入整数 n…

MATLAB算法实战应用案例精讲-【目标检测】机器视觉-工业相机

目录 前言 算法原理 机器视觉系统设计 照明设计 光学成像系统与相机

git常常用命令

这篇文章中&#xff0c;一些简单的&#xff0c;大家都知道的git 命令我就不再赘述&#xff0c;我只写出来最近在项目中常用到的一些命令。这些命令可以帮助我更好的开发。 git stash 请大家设想下面的场景&#xff0c;你的本地有两个分支&#xff0c;develop,fix分支&#xf…

CentOS基Docker容器时区配置解决方案

配置Docker容器的时区对于确保应用程序正确处理日期和时间至关重要。当使用CentOS作为基础镜像时&#xff0c;可以通过以下两种方法配置时区&#xff1a; 方法一&#xff1a;在Dockerfile中设置时区 这种方法涉及在构建Docker镜像的过程中设置时区。 步骤 选择基础镜像&…

ModuleNotFoundError: No module named ‘unstructured‘

使用pip install unstructured下载不下来 把unstructured的whl文件下载到本地安装也没成功&#xff0c;把punkt加载到nltk&#xff0c;这种方法也没成功 import nltk nltk.download(punkt) python版本当时是3.9.12&#xff0c;不知道是里面哪个包有冲突&#xff0c;时间有限…

禁止linux shell 终端显示完整工作路径,如何让linux bash终端不显示当前工作路径

在操作linux时&#xff0c;默认安装的linux终端会显示当前完整的工作目录&#xff0c;如果目录比较短还是可以接收&#xff0c;如果目录比较长&#xff0c;就显得比较别扭&#xff0c;操作起来不方便&#xff0c;因此需要关闭这种功能。 要关闭这个功能&#xff0c;请按如下步骤…

【书籍篇】Git 学习指南(二)提交与多次提交

Git 学习指南&#xff08;二&#xff09;提交与多次提交 三. 提交3.1 访问权限与时间戳3.2 add与commit3.3 再谈提交散列值3.4 提交历史3.5 略有不同的提交查看方法3.6 同一项目的多部不同历史 四. 多次提交4.1 status命令4.1.1 选择性修改 4.2 存储在暂存区中的快照4.3 怎样的…

智能座舱架构与芯片- (11) 软件篇 上

一、智能汽车基础软件平台分类 汽车软件主要分为应用软件和基础软件。应用软件和业务形态高度关联&#xff0c;不同控制器的应用软件之间差异较大。基础软件介于应用软件和硬件之间&#xff0c;用于屏蔽硬件特性、支撑应用软件。可有效地实现应用软件与硬件之间解耦&#xff0…

ky10 server x86 安装、更新openssl3.1.4(在线编译安装、离线安装)

查看openssl版本 openssl version 离线编译安装升级 #!/bin/shOPENSSLVER3.1.4OPENSSL_Vopenssl versionecho "当前OpenSSL 版本 ${OPENSSL_V}" #------------------------------------------------ #wget https://www.openssl.org/source/openssl-3.1.4.tar.gzech…

【Python】学习Python面向对象编程的疑问

&#xff08;Java菜鸟来学Python了&#xff09; &#x1f914; 1. 静态方法与类方法什么区别&#xff1f; 实例方法只能被实例对象调用(Python3 中&#xff0c;如果类调用实例方法&#xff0c;需要显示的传self, 也就是实例对象自己)&#xff0c;静态方法(由staticmethod装饰…

LangChain 6根据图片生成推广文案HuggingFace中的image-caption模型

根据图片生成推广文案&#xff0c; 用的HuggingFace中的image-caption模型 LangChain 实现给动物取名字&#xff0c;LangChain 2模块化prompt template并用streamlit生成网站 实现给动物取名字LangChain 3使用Agent访问Wikipedia和llm-math计算狗的平均年龄LangChain 4用向量数…

STM32 寄存器配置笔记——系统时钟配置 HSE as PLL

一、概述 本文主要介绍使用HSE高速外部时钟通过PLL倍频输出72MHZ的时钟作为系统时钟。下图为时钟树。 使用正点原子的开发板调试OSC_IN、OSC_OUT接的是8MHZ的晶振即为HSE时钟。 二、配置流程 1&#xff09;复位RCC相关的所有寄存器 复位内容是参考正点原子例程&#xff0c;按照…

云计算:开辟数字时代的无限可能

云计算是一项革命性的技术&#xff0c;为企业和个人提供了灵活、可扩展和高效的计算资源。本文将介绍云计算的概念、架构和优势&#xff0c;并探讨其在数字化时代的重要性和未来发展趋势。 引言 随着信息技术的日新月异和数字化转型的浪潮席卷全球&#xff0c;云计算作为一种颠…

深入Tailwind CSS中的文本样式

深入Tailwind CSS中的文本样式 样式文本是网页设计的一个基本组成部分&#xff0c;而 Tailwind CSS 提供了范围广泛的实用类&#xff0c;使文本样式设计既高效又有效。 在本本中&#xff0c;我们将探索文本样式的常见最佳实践,讨论潜在的陷阱&#xff0c;并推荐设计方法。我们…

多元函数奇偶性

多元函数奇偶性 多元函数的定义域 定义域根据函数的变量数不同,有不同的形式 一元函数 y f ( x ) yf(x) yf(x),定义域可以是数集二元函数 z f ( x , y ) zf(x,y) zf(x,y),定义域可以是一平面区域,是平面点集三元函数 v f ( x , y , z ) vf(x,y,z) vf(x,y,z),定义域是一块空…

ZYNQ_project:lcd_pic_400x400

在lcd液晶屏上显示400x400像素的图片&#xff0c; 像素信息通过电脑的串口调试助手&#xff0c;发送给fpga&#xff0c;存储在例化的双端口ram中&#xff0c; 在要显示图像区域&#xff0c;读取ram中的像素信息。 模块框图&#xff1a; 时序图&#xff1a; 代码&#xff1a;…