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 足够大时∣Σ∣可忽略。

代码实现

代码实现(思路一(栈+哈希表)):
cpp 复制代码
class Solution {
public:
    bool isValid(string s) {
        //如果左右括号总数是奇数,直接返回false
        if (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();
            
    }
};
以思路一为例进行调试
cpp 复制代码
#include<iostream>
#include<stack>
#include<unordered_map>
using namespace std;

class Solution {
public:
    bool isValid(string s) {
        //如果左右括号总数是奇数,直接返回false
        if (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)原题链接

欢迎大家和我沟通交流(✿◠‿◠)

相关推荐
xlq223222 小时前
22.多态(上)
开发语言·c++·算法
D_evil__2 小时前
[C++高频精进] 并发编程:线程基础
c++
云里雾里!3 小时前
力扣 209. 长度最小的子数组:滑动窗口解法完整解析
数据结构·算法·leetcode
Mr_WangAndy3 小时前
C++17 新特性_第二章 C++17 语言特性_std::any和string_view
c++·string_view·c++40周年·c++17新特性·c++新特性any
CoderYanger4 小时前
递归、搜索与回溯-穷举vs暴搜vs深搜vs回溯vs剪枝:12.全排列
java·算法·leetcode·机器学习·深度优先·剪枝·1024程序员节
水天需0105 小时前
C++ 三种指针转换深度解析
c++
言言的底层世界5 小时前
c++中STL容器及算法等
开发语言·c++·经验分享·笔记
Mr_WangAndy5 小时前
C++17 新特性_第一章 C++17 语言特性___has_include,u8字符字面量
c++·c++40周年·c++17新特性·__has_include·u8字面量
liu****6 小时前
八.函数递归
c语言·开发语言·数据结构·c++·算法
Vanranrr6 小时前
C++临时对象与悬空指针:一个导致资源加载失败的隐藏陷阱
服务器·c++·算法