栈-20.有效的括号-力扣(LeetCode)

一、题目解析

对于这个字符串需要左右括号匹配,并且是以正确的顺序

二、算法原理

解法1.图+栈

解法2.用else if代替图+栈

正常做法:对于三种左括号直接进栈('(','[','{'进栈),然后判断与下一个括号是否匹配,匹配则出栈,不匹配则返回false。

改进:当遇到三种左括号时,可以进栈对应的右括号(')',']','}'进栈),然后判断与下一个括号是否相同,当栈为空或者栈顶元素括号不匹配时,返回false,然后出栈。

最后返回值为栈是否为空,为空则返回true,所有括号匹配完,反之为false。

思考过后可以自己实现一下,链接:20. 有效的括号 - 力扣(LeetCode)

三、代码示例

class Solution {
public:bool isValid(string s) {stack<char> k;for(auto e : s){if(e == '(') k.push(')');else if(e == '[') k.push(']');else if(e == '{') k.push('}');else{if(k.empty() || k.top() != e) return false;k.pop();}}return k.empty();}
};

 

 

看到最后,如果对您有所帮助,还请点赞、收藏和关注,点点关注不迷路,我们下期再见! 

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

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

相关文章

将音频数据累积到缓冲区,达到阈值时触发处理

实现了音频处理中的 AEC&#xff08;声学回声消除&#xff09;和 AES&#xff08;音频增强&#xff09;功能&#xff0c;其核心功能是&#xff1a; 数据缓冲管理&#xff1a;将输入的麦克风和扬声器音频数据块累积到缓冲区中块处理机制&#xff1a;当缓冲区填满预设大小&#…

fastadmin+workman环境搭建

一、出现错误 从git拉取到本地在配置网址登录后出现 unserialize(): Error at offset 0 of 17039 bytes 参考&#xff1a;https://blog.csdn.net/yqwwj001/article/details/88688675 找到 \thinkphp\library\think\cache\driver\Flie.php 中的 $content substr($content, …

若依+vue2实现模拟登录

1、背景 第三方通过链接访问若依项目&#xff0c;该链接通过携带唯一标识符&#xff1a;phone&#xff08;手机号&#xff09;&#xff0c;项目通过手机号查询本项目数据库人员信息实现模拟登录。 2、实现 2.1. 前端实现 2.1.1 创建专用模拟登录页面PhoneLogin.vue <te…

【2025】使用docker compose一键部署项目到服务器(4)

目录&#x1f4bb; 前言一、部署准备二、本地idea配置docker和docker compose执行器三、编写docker-compose.yml文件四、执行启动 前言 该篇文章主要是使用idea通过docker-compose.yml构建容器集合并且进行统一管理更新 该专栏主要为介绍通过docker compose实现容器编排部署 &…

Linux Windows之wsl安装使用简介

参考资料 如何使用 WSL 在 Windows 上安装 Linuxwindows11 安装WSL2全流程旧版 WSL 的手动安装步骤 目录 一. 前期准备1.1 确认windows的版本1.2 开启Linux子系统的支持1.2.1 图形化方式1.2.2 命令行方式 1.3 安装wsl软件1.4 安装Linux分发版 二. 基本配置2.1 Windows Termina…

matlab模糊控制实现路径规划

路径规划是机器人和自动驾驶系统中的重要问题之一&#xff0c;它涉及确定如何在给定环境中找到最优路径以达到特定目标。模糊控制是一种有效的控制方法&#xff0c;可以应用于路径规划问题。 路径规划算法的目标是在避免障碍物的情况下&#xff0c;找到机器人或车辆从起点到终…

OpenHarmony 5.0横竖屏界面适配

目录 一.背景 二.修改位置 三.参考文档 一.背景 由于需要一套代码适配横屏和竖屏设备,所以有些数值的大小可能在竖屏上面适配,在横屏上面不那么适配了,所以需要横屏特殊的数值大小(例如:宽高) 二.修改位置 在resources资源文件中新建横屏适配的文件夹,然后新建自己需…

AlphaFold3服务器安装与使用(非docker)(1)

1. 服务器显卡驱动准备 这部分我会详细记录一下我踩过的坑及怎样拯救的&#xff0c;原谅啰嗦啦 ^_^ 1.1 服务器旧配置 1.1.1 nvidia-smi [xxxxxxlocalhost ~]# nvidia-smi Thu May 29 20:54:00 2025 -------------------------------------------------------------…

Java异步编程难题拆解技术

目录 ​编辑 异步编程的核心概念 Java异步编程的主要实现方式 异步编程的常见难题 解决异步编程难题的策略 性能优化与调试技巧 实际案例分析 未来发展趋势 异步编程的核心概念 同步与异步的区别阻塞与非阻塞的差异Java异步编程的常见场景&#xff08;如网络请求、文件…

第五期书生大模型实战营-《L1G1-玩转书生大模型 API 之 Browser-Use 实践》

一、 搭建环境 pip install requests openai 1.2、获取API https://internlm.intern-ai.org.cn/api/tokens 1.3 运行API from openai import OpenAI from dotenv import load_dotenv import osfrom openai import OpenAI from dotenv import load_dotenv import os# Inter…

基于Web的安全漏洞分析与修复平台设计与实现

基于Web的安全漏洞分析与修复平台设计与实现 摘要 随着信息化进程的加快&#xff0c;Web系统和企业IT架构愈发复杂&#xff0c;安全漏洞频发已成为影响系统安全运行的主要因素。为解决传统漏洞扫描工具定位不准确、修复建议不完善、响应周期长等问题&#xff0c;本文设计并实…

深入解析异步爬虫中的协程原理:从概念到工程实践

引言 在Web数据抓取领域,同步爬虫的​​单线程阻塞模型​​已无法满足现代应用对效率的需求。据统计,2025年全球Top 1000网站中,89%采用Ajax动态加载技术,传统爬虫的平均抓取效率已下降至每秒1.5个页面。而基于协程的异步爬虫通过​​非阻塞I/O​​和​​并发调度​​,可…

告别硬编码!用工厂模式优雅构建可扩展的 Spring Boot 应用 [特殊字符]

嗨&#xff0c;各位技术伙伴们&#xff01;&#x1f44b; 在日常的软件开发中&#xff0c;我们经常面临需求变更的挑战。如何构建一个既能满足当前需求&#xff0c;又能轻松应对未来变化的系统呢&#xff1f;答案往往藏在那些经典的设计模式中。 今天&#xff0c;我们就来聊聊…

【Linux】编译器gcc/g++及其库的详细介绍

前言&#xff1a; 上文我们学到了&#xff0c;LInux中的的编辑器vim【Linux】vim编辑器-CSDN博客 本文来学习LInux中的编译器&#xff1a;gcc/g gcc是C语言编译器&#xff0c;g是C编译器&#xff0c;这两个的使用一模一样。这里我们主要使用gcc给大家介绍 1.格式 gcc 被编译的…

用“红烧鱼”类比说明卷积神经网络CNN的概念

我们用一个生活中的例子——「厨房做红烧鱼」 的场景&#xff0c;来类比卷积神经网络中多层卷积核的工作过程。你会发现&#xff0c;卷积层就像厨房里分工明确的厨师团队&#xff0c;逐步处理食材&#xff0c;最终完成一道复杂的菜品。 &#x1f41f; 生活案例&#xff1a;厨房…

uniapp与微信小程序开发平台联调无法打开IDE

经测试属于网络问题。本机需要联网。否则会出现Hbuilder运行微信小程序到模拟器时无法打开 微信开发者工具 这个页面出不来会一直显示异常。这期间微信小程序开发工具的端口是通的 需要先联网

内网穿透之Linux版客户端安装(神卓互联)

选择Linux系统版本 获取安装包 &#xff1a;https://www.shenzhuohl.com/download.html 这里以Ubuntu 18.04为例&#xff0c;其它版本方法类似 登录Ubuntu操作系统&#xff1a; 打开Ubuntu系统终端&#xff0c;更新版本 apt-get update 安装运行环境&#xff1a; 安装C 运…

硬件学习笔记--66 MCU的DMA简介

DMA&#xff08;Direct Memory Access&#xff0c;直接存储器访问&#xff09;是MCU中一种重要的数据传输机制&#xff0c;它允许外设与存储器之间或存储器与存储器之间直接传输数据&#xff0c;而无需CPU的持续干预。 1、DMA的基本原理 1.1 核心概念&#xff1a; 1&#xf…

DeepSeek本地部署及WebUI可视化教程

前言 DeepSeek是近年来备受关注的大模型之一,支持多种推理和微调场景。很多开发者希望在本地部署DeepSeek模型,并通过WebUI进行可视化交互。本文将详细介绍如何在本地环境下部署DeepSeek,并实现WebUI可视化,包括Ollama和CherryStudio的使用方法。 一、环境准备 1. 硬件要…

RK3588和FPGA桥片之间IO电平信号概率性不能通信原因

1.GPIO管脚配置问题 RK3588对IO进行配置的时候&#xff0c;如果配置为多功能复用&#xff0c;没有明确IO功能&#xff0c;可能引起信号接收不稳定&#xff0c; 需要在驱动中设备树中配置管脚为GPIO功能&#xff0c;确保没有功能复用的干扰。 2.上下拉电阻阻值设置不当 GPIO引脚…