小奥的学习笔记

  • Home
  • Learning & Working
    • Speech Enhancement Notes
    • Programming language
    • Computer & DL
    • MOOC
  • Life
    • Life Time
    • Thinking & Comprehension
    • Volunteer
    • Plan
    • Travel
  • Footprints
  • GuestBook
  • About
    • About Me
    • 个人履历
    • 隐私策略
  1. 首页
  2. Study-notes
  3. Programming language
  4. Algorithm
  5. Leetcode
  6. 正文

Leetcode题目解析(191217):20&22&32

2019年12月17日 1210点热度 0人点赞 0条评论

Leetcode 20:有效的括号

题目描述

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

有效字符串需满足:

左括号必须用相同类型的右括号闭合。
左括号必须以正确的顺序闭合。

注意空字符串可被认为是有效字符串。

代码实现

bool isValid(string s) {
    if (s.empty())
        return true;
    if (s.size() % 2 == 1)
        return false;
    stack<char> tt;
    for (int i = 0; i < s.size(); i++)
    {
        if (s[i] == '(')
            tt.push(')');
        else if (s[i] == '[')
            tt.push(']');
        else if (s[i] == '{')
            tt.push('}');
        else if (tt.empty() || tt.top() != s[i])
            return false;
        else
            tt.pop();
    }
    return tt.empty();
}

复杂度

时间复杂度:O(n),n为字符串长度
空间复杂度:O(n),n为字符串长度

复杂度分析

Leetcode 22:括号生成

题目描述

给出 n 代表生成括号的对数,请你写出一个函数,使其能够生成所有可能的并且有效的括号组合。例如,给出 n = 3,生成结果为:

[
  "((()))",
  "(()())",
  "(())()",
  "()(())",
  "()()()"
]

解题思路

用回溯法可以比较容易的做出来,因为前面回溯法说的比较多了,这里就不再累述。但是有一点注意的是,backtrack()中第三个判断一定要是right<left才可以,而不是right<n,因为right的数量目标是等于left,在已经有了left个左括号的时候,右括号数量right不能超过left。

代码实现

void backtrack(int left,int right, int n, string& s, vector<string>& result)
{
    if (left == n && right == n)
    {
        result.push_back(s);
        return;
    }
    if (left < n) {
        s += "(";
        backtrack(left + 1, right, n, s, result);
        s.pop_back();
    }
    //下面的意思是,右括号不可能多于左括号的数量,当然也不能少于左括号的数量
    if (right < left) {
        s += ")";
        backtrack(left, right + 1, n, s, result);
        s.pop_back();
    }
    
}
vector<string> generateParenthesis(int n) {
    vector<string> res;
    string s;
    backtrack(0, 0, n, s, res);
    return res;
}

复杂度

复杂度分析

Leetcode 32:最长有效括号

题目说明

给定一个只包含 '(' 和 ')' 的字符串,找出最长的包含有效括号的子串的长度。

解题思路

参考:https://leetcode-cn.com/problems/longest-valid-parentheses/solution/c-liang-ci-bian-li-jie-fa-by-da-li-wang/

代码实现

int longestValidParentheses(string s) {
    int res = 0;
    int left = 0;
    int mark = 0;
    //从左到右
    for (int i = 0; i < s.size(); ++i) {
        int prev_mark = mark;
        mark = max(0, mark + ((s[i] == '(') ? 1 : -1));
        if (mark == 0) {
            if (prev_mark > 0) {
                res = max(i - left + 1, res);
            }
            else {
                left = i + 1;
            }
        }
    }
    mark = 0;
    int right = s.size() - 1;
    //从右到左
    for (int i = s.size() - 1; i >= 0; --i) {
        int prev_mark = mark;
        mark = max(0, mark + ((s[i] == ')') ? 1 : -1));
        if (mark == 0) {
            if (prev_mark > 0) {
                res = max(right - i + 1, res);
            }
            else {
                right = i - 1;
            }
        }
    }
    return res;
}

复杂度

复杂度分析
空间复杂度:O(n)【dp数组长度】
时间复杂度:O(n)

本作品采用 知识共享署名 4.0 国际许可协议 进行许可
标签: leetcode
最后更新:2019年12月17日

davidcheung

这个人很懒,什么都没留下

打赏 点赞
< 上一篇

文章评论

razz evil exclaim smile redface biggrin eek confused idea lol mad twisted rolleyes wink cool arrow neutral cry mrgreen drooling persevering
取消回复

搜索
欢迎关注我的个人公众号
最新 热点 随机
最新 热点 随机
DEEPFILTERNET:一种基于深度滤波的全频带音频低复杂度语音增强框架 奥地利匈牙利九日游旅程 论文阅读之Study of the General Kalman Filter for Echo Cancellation 小奥看房之鸿荣源珈誉府 杭州往返旅途及西溪喜来登和万怡的体验报告 2022年的第一篇碎碎念
奥地利匈牙利九日游旅程小奥看房之鸿荣源珈誉府论文阅读之Study of the General Kalman Filter for Echo CancellationDEEPFILTERNET:一种基于深度滤波的全频带音频低复杂度语音增强框架
吴恩达深度学习课程DeepLearning.ai笔记(2-1) Python chapter 8 learning notes 中考目标公布 WordPress将文章同步到新浪微博的几种方法(三种) 资料收集:Adobe CS6我所需要的软件下载集合 WordPress代码高亮插件SyntaxHighlighter终极使用详解
标签聚合
鸟哥的linux私房菜 leetcode 生活 linux 高中 学习 python学习 Java 算法 Python
最近评论
davidcheung 发布于 5 个月前(02月09日) The problem has been fixed. May I ask if you can s...
tk88 发布于 5 个月前(02月07日) Hmm is anyone else having problems with the pictur...
cuicui 发布于 9 个月前(10月20日) :wink:
niming 发布于 10 个月前(09月19日) 同级校友,能刷到太巧了
davidcheung 发布于 2 年前(08月16日) 我得找一下我之前整理的word文档看一下,如果找到了我就更新一下这篇文章。
Nolan 发布于 2 年前(07月25日) 您的笔记非常有帮助。贴图不显示了,可以更新一下吗?
davidcheung 发布于 3 年前(06月19日) 到没有看webrtc的代码。现在主要在看我们公司的代码了。。。只是偶尔看一看webrtc的东西。。。
aobai 发布于 3 年前(03月13日) gain_change_hangover_ 应该是每三个block 只能够调整一次,这样保证每帧...
匿名 发布于 5 年前(12月30日) 烫
小奥 发布于 5 年前(12月12日) webRTC里面的NS本身我记得就是在C++里面呀

COPYRIGHT © 2025 小奥的学习笔记. ALL RIGHTS RESERVED.

Theme Kratos Made By Seaton Jiang

陕ICP备19003234号-1

鲁公网安备37120202000100号