LeetCode 20.有效的括号 C写法

LeetCode 20.有效的括号 C写法

image-20240715192544611

思路🧐:

​   这题最优思路是用来进行匹配,如果是左括号入栈,如果是右括号那么左括号出栈去匹配,匹配成功就继续入栈或者出栈,匹配失败则字符串无效。不过C语言没有STL库,所以我们要手写一个栈(栈代码都在该篇博客中)出来。

代码🔎:

bool isValid(char * s){ST st; // 注意这里要把数据类型更改成charStackInit(&st);while(*s){//左括号入栈if(*s == '[' || *s == '(' || *s == '{'){StackPush(&st, *s);++s;}else{if(StackEmpty(&st)) //没有左括号的情况,出不了栈{StackDestory(&st); //防止内存泄漏return false;}char top = StackTop(&st); //取栈顶的符号StackPop(&st); //出栈if((*s == ']' && top !='[') || (*s == ')' && top != '(')|| (*s == '}' && top != '{')) //结束的条件,不匹配直接结束{StackDestory(&st);return false;}else{++s;}}}bool ret = StackEmpty(&st);  //防止全是左括号凑巧走到最后一步的情况StackDestory(&st);return ret;
}

image-20240715203107892

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

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

相关文章

win10远程ubuntu服务器桌面且显示图像窗口工具及配置说明

仅需一个MobaXterm_Personal工具就可以实现 网上的教程比较多,实现起来比较复杂,这个是经过自己的钻研找到的方法(请勿转载和抄袭) 报错:cannot connect to X server :0.0 操作1:export DISPLAY自己windo…

python 语法学习(总结类) day 3

一、数据类型 1 整数类型 int 2 浮点数类型 float 3 复数类型 二、字符串类型 1 字符串类型 2 字节串类型(很少用到) 三、组合类型 1 集合类型:一维数组的集合 2 元组…

PHP基础认知

PHP(Hypertext Preprocessor,即“超文本预处理器”)是一种广泛使用的开源通用脚本语言,特别适合用于Web开发。其基础语法涵盖了多个方面,包括标记与注释、数据类型、变量、运算符、控制结构等。以下是PHP基础语法的详细…

【网络安全】资产记录工具 Hacker Asset Logger 安装使用详细教程

原创文章,不得转载。 文章目录 工具介绍安装地址使用方式工具介绍 在对某一应用程序的多个页面、对多个相关联的应用程序进行渗透测试的过程中,多个请求包的参数、功能之间可能存在一定的联系。 例如,在A页面触发的请求包中,通过UID可获取CustomerID;在B页面触发的请求包…

SSE、Webworker 、webSocket、Http、Socket 服务器推送技术

Http协议 受浏览器的同源策略限制 HTTP 协议是一种无状态的、无连接(短暂连接,客户端发送请求,服务器响应后即断开连接)的、单向的应用层协议。 它采用了请求/响应模型。通信请求只能由客户端发起,服务端对请求做出应…

浅谈网络安全防守:从被动应对到主动管理的转变

浅谈网络安全防守:从被动应对到主动管理的转变 背景: 在当今的数字时代,网络安全已成为企业生存和发展的重要基石。然而,当企业的网络安全体系面临着诸如资产不清、互联网应用管理混乱、边界防火墙策略失效、长期未修复的漏洞、…

IP地址与物理地址:网络通信的基础详解

在学习网络通信时,理解IP地址与物理地址(也称为硬件地址)的区别至关重要。这篇文章将为你解答这些基本概念,并帮助你更好地掌握网络通信的基础。 什么是IP地址和物理地址? IP地址是网络层的逻辑地址,用于标…

leetcode算法题(反转链表)

思路1: 创建新的链表,遍历原链表,将原链表的节点进行头插到新链表中。 struct ListNode* reverseList(struct ListNode* head) {struct ListNode* next NULL;struct ListNode* new_head NULL;if (head NULL ||head->next NULL) // 空…

Java8 根据List实体中一个字段去重取最大值,并且根据该字段进行排序

1、前言 某个功能要求需要对一个list对象里数据按照股票分组,并且取分组涨跌幅最大的,返回一个新的list对象,并且按照涨跌幅字段进行排序,这么一连串的要求,如果按照传统的写法,我们需要写一大坨的代码&am…

AWS云计算实战:电商平台发卡机器人开发指南

在当今数字化时代,电商平台的自动化运营变得尤为重要。本文将深入探讨如何利用AWS云计算平台开发一款高效的发卡机器人,旨在提高电商平台的自动化水平和用户体验。 关键词 AWS云计算, 电商平台, 发卡机器人 1. 引言 随着电商行业的蓬勃发展&#xff…

Python 获取今天(当天)、昨天(前一天)、前天(昨天的前一天)的开始时间、结束时间

描述:我这里是封装成DatetimeHelper工具类来调用 1.今天(当天)开始时间、结束时间 from datetime import datetime, timedeltaclass DatetimeHelper:# 获取今天(当天)的开始时间、结束时间(datetime类型)staticmethoddef getTodayStartEnd():# 获取当前的日期now …

编织微服务网络:在Eureka中打造分布式服务网格

编织微服务网络:在Eureka中打造分布式服务网格 在微服务架构的复杂网络中,服务间的通信和管理变得愈加复杂。服务网格(Service Mesh)作为一种微服务间通信的基础设施层,负责处理服务发现、负载均衡、故障恢复等任务。…

在 electron+vite+vue3+express 项目中使用better-sqlite3

文章目录 一、安装 electron-rebuild 和 better-sqlite3二、使用 electron-rebuild 重建 Node.js 模块三、better-sqlite3 的基本使用四、打包五、参考资料 一、安装 electron-rebuild 和 better-sqlite3 yarn add -D electron-rebuild yarn add better-sqlite3Electron 内置的…

Hive 常见问题

Hive 内部表和外部表的区别 外部表在创建时需要加关键字 external;创建内部表时,会将数据移动到数据仓库指定的路径;创建外部表时,不会移动数据,只会记录数据所在的路径;删除内部表时,会删除元…

解决onlyoffice无法重命名的问题

当前的问题: 返回的是 error:1,根据官方文档的解释,这个是文档的key是错误的。 参考官方文档:https://api.onlyoffice.com/zh/editors/command 解决思路:看有没有什么事件,能够携带文档的key…

【计算机视觉前沿研究 热点 顶会】CVPR 2024中与3D目标检测、BEV、Lidar、自动驾驶相关的论文

UniMODE:统一的单目 3D 目标检测 实现包括室内和室外场景的统一单目 3D 目标检测在机器人导航等应用中具有重要意义。然而,涉及数据的各种场景来训练模型会带来挑战,因为它们具有显著不同的特性,例如不同的几何特性和异构的域分布…

pytorch学习(一)argparse

""" 主要学习内容 1. type default help action choice dest 2. required 为True的时候必须要初始化 3. nargs课代表List 4.流程 import argparse parser argparse.ArgumentParser(descriptionTrain network) arser.add_argument() args1 parser.parse_args(&…

无人机图像目标检测

本仓库是人工智能课程的课程作业仓库,主要是完成无人机图像目标检测的任务,我们对visdrone数据集进行了处理,在yolo和ssd两种框架下进行了训练和测试,并编写demo用于实时的无人机图像目标检测。 requirements依赖: ss…

01- 收入数据集【Pytorch入门实战】

目录 一、机器学习基础 二、实战例子 1.数据集分析 2.实战训练 3.总结 三、参考资料 一、机器学习基础 为了解决这个问题,人们想到数据驱动方法,也就是让计算机从现有的大量的带标签图片电学习规律,一旦计算机学习到了其中的规律&…

LLM量化--AWQ论文阅读笔记

写在前面:近来大模型十分火爆,所以最近开启了一波对大模型推理优化论文的阅读,下面是自己的阅读笔记,里面对文章的理解并不全面,只将自己认为比较重要的部分摘了出来,详读的大家可以参看原文 原论文地址&am…