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

LeetCode 面试经典 150_栈_有效的括号(52_20_C++_简单)(栈+哈希表)

LeetCode 面试经典 150_栈_有效的括号(52_20_C++_简单)

    • 题目描述:
    • 输入输出样例:
    • 题解:
      • 解题思路:
        • 思路一(栈+哈希表):
      • 代码实现
        • 代码实现(思路一(栈+哈希表)):
        • 以思路一为例进行调试

题目描述:

给定一个只包括 ‘(’,‘)’,‘{’,‘}’,‘[’,‘]’ 的字符串 s ,判断字符串是否有效。

有效字符串需满足:
1、左括号必须用相同类型的右括号闭合。
2、左括号必须以正确的顺序闭合。
3、每个右括号都有一个对应的相同类型的左括号。

输入输出样例:

示例 1:
输入:s = “()”
输出:true

示例 2:
输入:s = “()[]{}”
输出:true

示例 3:
输入:s = “(]”
输出:false

示例 4:
输入:s = “([])”
输出:true

提示:
1 <= s.length <= 104
s 仅由括号 ‘()[]{}’ 组成

题解:

解题思路:

思路一(栈+哈希表):

1、将左右括号的对应关系存储在哈希表中,key存储右括号,value存储左括号(因左括号只有入栈的操作,而右括号需判断栈顶有没有与之对应的左括号)。
① 先检查数组中元素的个数,如果为偶数,则有可能是有效的括号。如果为奇数,则不可能为有效的括号返回false。
② 当是左括号时,左括号入栈。
③ 当是右括号时,栈顶存在与之对应的左括号,则左括号出栈。若不存在与之对应的左括号则返回false。
④ 若最后栈为空则返回true,否则返回false。

2、复杂度分析
① 时间复杂度:O(n),n 是字符串 s 的长度。
② 空间复杂度:O(n+∣Σ∣),n 是字符串 s 的长度,Σ 表示字符集,本题中字符串只包含 6 种括号,∣Σ∣=6。栈中字符数最多为 n(例如全是左括号),栈中的字符数量为 O(n)。当 n 足够大时∣Σ∣可忽略。

代码实现

代码实现(思路一(栈+哈希表)):
class Solution {
public:bool isValid(string s) {//如果左右括号总数是奇数,直接返回falseif (s.size()%2==1) return false;//创建左右括号的对应关系,注意key=右括号,value=左括号(因左括号直接入栈无其他情况)unordered_map<char,char> mp={{')','('},{']','['},{'}','{'}};stack<char> stk;//对字符串中的每个字符进行判断for (const auto &ch :s){//如果是右括号if (mp.count(ch)){//当右括号且栈空或者左右括号不匹配返回false匹配失败if (stk.empty() || stk.top()!=mp[ch]){return false;}//当左右括号对应则出栈else{stk.pop();}//左括号直接入栈}else{stk.push(ch);}}//如果最后栈为空则返回true,否则返回false(其中只有左括号)return stk.empty();}
};
以思路一为例进行调试
#include<iostream>
#include<stack>
#include<unordered_map>
using namespace std;class Solution {
public:bool isValid(string s) {//如果左右括号总数是奇数,直接返回falseif (s.size()%2==1) return false;//创建左右括号的对应关系,注意key=右括号,value=左括号(因左括号直接入栈无其他情况)unordered_map<char,char> mp={{')','('},{']','['},{'}','{'}};stack<char> stk;//对字符串中的每个字符进行判断for (const auto &ch :s){//如果是右括号if (mp.count(ch)){//当右括号且栈空或者左右括号不匹配返回false匹配失败if (stk.empty() || stk.top()!=mp[ch]){return false;}//当左右括号对应则出栈else{stk.pop();}//左括号直接入栈}else{stk.push(ch);}}//如果最后栈为空则返回true,否则返回false(其中只有左括号)return stk.empty();}
};int main(int argc, char const *argv[])
{string s="((()))";//判断有效的括号Solution s1;if (s1.isValid(s)){cout<<"true"<<endl;}else{cout<<"false"<<endl;}return 0;
}

LeetCode 面试经典 150_栈_有效的括号(52_20)原题链接
欢迎大家和我沟通交流(✿◠‿◠)

http://www.dtcms.com/a/491761.html

相关文章:

  • Wine 10.15 发布!Linux 跑 Windows 应用更丝滑了
  • 国外家居设计网站温州建设信息网站
  • PT2000 Dev Studio产生的微码解析一-微核简介
  • UVa 10228 A Star not a Tree?
  • 管理系统网站开发赚钱小程序
  • 五、安装配置hive
  • 自己给公司做网站5g天天奭5g天天运动网站代码
  • Kafka Queue: 完成 alterShareGroupOffsets Api
  • 网站开发流程 原型设计深圳世茂前海中心
  • Secret 与 ConfigMap配置资源管理
  • 泛微 企业网站建设计划网站开发后台框架
  • 做网站怎么添加图片企业营业执照查询系统入口
  • 大气污染扩散Calpuff模型应用
  • 【LeetCode热题100(44/100)】二叉树的右视图
  • 打工人日报#202510016
  • 青岛公司建设网站添加友情链接的技巧
  • 10.2.3 TrinityCore 网络模块封装
  • JS逆向-安全辅助项目接口联动JSRpc进阶调用BP插件autoDecode(下)
  • 试客网站程序源码南京网站制作步骤
  • 外贸网站用什么空间好福州网站建设优化
  • RoboIntern,一款自动化办公小助手
  • 前端中的受控组件与非受控组件:核心区别与实践指南
  • 逻辑600解析本03
  • 青海省建设厅建管处网站淘宝关键词排名优化
  • Day32_【 NLP _2.RNN及其变体 _(3) GRU】
  • 网站建设毕业设计刻光盘网站开发前景知乎
  • Git的diff命令
  • VBA 自动解压 WinZip 文件
  • 站长号制作网站副本
  • BSC 链的第二次觉醒:从山寨天堂到流动性引擎的演化逻辑