iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >C++实现最长有效括号的方法
  • 768
分享到

C++实现最长有效括号的方法

2023-06-20 15:06:48 768人浏览 薄情痞子
摘要

这篇文章主要讲解了“c++实现最长有效括号的方法”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C++实现最长有效括号的方法”吧!Longest Valid Parentheses 最长有效括

这篇文章主要讲解了“c++实现最长有效括号的方法”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C++实现最长有效括号的方法”吧!

Longest Valid Parentheses 最长有效括号

Given a string containing just the characters '(' and ')', find the length of the longest valid (well-fORMed) parentheses substring.

Example 1:

Input: "(()"
Output: 2
Explanation: The longest valid parentheses substring is "()"

Example 2:

Input: ")()())"
Output: 4
Explanation: The longest valid parentheses substring is "()()"

这道求最长有效括号比之前那道 Valid Parentheses 难度要大一些,这里还是借助栈来求解,需要定义个 start 变量来记录合法括号串的起始位置,遍历字符串,如果遇到左括号,则将当前下标压入栈,如果遇到右括号,如果当前栈为空,则将下一个坐标位置记录到 start,如果栈不为空,则将栈顶元素取出,此时若栈为空,则更新结果和 i - start + 1 中的较大值,否则更新结果和 i - st.top() 中的较大值,参见代码如下:

解法一:

class Solution {public:    int longestValidParentheses(string s) {        int res = 0, start = 0, n = s.size();        stack<int> st;        for (int i = 0; i < n; ++i) {            if (s[i] == '(') st.push(i);            else if (s[i] == ')') {                if (st.empty()) start = i + 1;                else {                    st.pop();                    res = st.empty() ? max(res, i - start + 1) : max(res, i - st.top());                }            }        }        return res;    }};

还有一种利用动态规划 Dynamic Programming 的解法。这里使用一个一维 dp 数组,其中 dp[i] 表示以 s[i-1] 结尾的最长有效括号长度(注意这里没有对应 s[i],是为了避免取 dp[i-1] 时越界从而让 dp 数组的长度加了1),s[i-1] 此时必须是有效括号的一部分,那么只要 dp[i] 为正数的话,说明 s[i-1] 一定是右括号,因为有效括号必须是闭合的。当括号有重合时,比如 "(())",会出现多个右括号相连,此时更新最外边的右括号的 dp[i] 时是需要前一个右括号的值 dp[i-1],因为假如 dp[i-1] 为正数,说明此位置往前 dp[i-1] 个字符组成的子串都是合法的子串,需要再看前面一个位置,假如是左括号,说明在 dp[i-1] 的基础上又增加了一个合法的括号,所以长度加上2。但此时还可能出现的情况是,前面的左括号前面还有合法括号,比如 "()(())",此时更新最后面的右括号的时候,知道第二个右括号的 dp 值是2,那么最后一个右括号的 dp 值不仅是第二个括号的 dp 值再加2,还可以连到第一个右括号的 dp 值,整个最长的有效括号长度是6。所以在更新当前右括号的 dp 值时,首先要计算出第一个右括号的位置,通过 i-3-dp[i-1] 来获得,由于这里定义的 dp[i] 对应的是字符 s[i-1],所以需要再加1,变成 j = i-2-dp[i-1],这样若当前字符 s[i-1] 是左括号,或者j小于0(说明没有对应的左括号),或者 s[j] 是右括号,此时将 dp[i] 重置为0,否则就用 dp[i-1] + 2 + dp[j] 来更新 dp[i]。这里由于进行了 padding,可能对应关系会比较晕,大家可以自行带个例子一步一步执行,应该是不难理解的,参见代码如下:

解法二:

class Solution {public:    int longestValidParentheses(string s) {        int res = 0, n = s.size();        vector<int> dp(n + 1);        for (int i = 1; i <= n; ++i) {            int j = i - 2 - dp[i - 1];            if (s[i - 1] == '(' || j < 0 || s[j] == ')') {                dp[i] = 0;            } else {                dp[i] = dp[i - 1] + 2 + dp[j];                res = max(res, dp[i]);            }        }        return res;    }};

此题还有一种不用额外空间的解法,使用了两个变量 left 和 right,分别用来记录到当前位置时左括号和右括号的出现次数,当遇到左括号时,left 自增1,右括号时 right 自增1。对于最长有效的括号的子串,一定是左括号等于右括号的情况,此时就可以更新结果 res 了,一旦右括号数量超过左括号数量了,说明当前位置不能组成合法括号子串,left 和 right 重置为0。但是对于这种情况 "(()" 时,在遍历结束时左右子括号数都不相等,此时没法更新结果 res,但其实正确答案是2,怎么处理这种情况呢?答案是再反向遍历一遍,采取类似的机制,稍有不同的是此时若 left 大于 right 了,则重置0,这样就可以 cover 所有的情况了,参见代码如下:

解法三:

class Solution {public:    int longestValidParentheses(string s) {        int res = 0, left = 0, right = 0, n = s.size();        for (int i = 0; i < n; ++i) {            (s[i] == '(') ? ++left : ++right;            if (left == right) res = max(res, 2 * right);            else if (right > left) left = right = 0;        }        left = right = 0;        for (int i = n - 1; i >= 0; --i) {            (s[i] == '(') ? ++left : ++right;            if (left == right) res = max(res, 2 * left);            else if (left > right) left = right = 0;        }        return res;    }};

感谢各位的阅读,以上就是“C++实现最长有效括号的方法”的内容了,经过本文的学习后,相信大家对C++实现最长有效括号的方法这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

--结束END--

本文标题: C++实现最长有效括号的方法

本文链接: https://www.lsjlt.com/news/298027.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • C++实现最长有效括号的方法
    这篇文章主要讲解了“C++实现最长有效括号的方法”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C++实现最长有效括号的方法”吧!Longest Valid Parentheses 最长有效括...
    99+
    2023-06-20
  • C++实现LeetCode(32.最长有效括号)
    [LeetCode] 32. Longest Valid Parentheses 最长有效括号 Given a string containing just the characte...
    99+
    2024-04-02
  • C++实现验证括号的方法
    本篇内容介绍了“C++实现验证括号的方法”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!Valid Parentheses 验证括号Given...
    99+
    2023-06-20
  • Java移除无效括号的方法实现
    目录一、题目二、示例三、解法1四、解法2一、题目 给你一个由 ‘('、')' 和小写字母组成的字符串 s。 你需要从字符串中删除最少数目的 ‘(' 或者 ‘)' (可以删除任意位置...
    99+
    2024-04-02
  • C语言实现括号配对的方法示例
    本文主要介绍了C语言实现括号配对的方法示例,分享给大家,具体如下: 代码如下: #include<stdio.h> #include<string.h> ...
    99+
    2024-04-02
  • python实现有效的括号判断实例代码
    目录题目描述测试用例代码实现总结题目描述 给定一个只包括 '(',')','{','}','[',&#...
    99+
    2024-04-02
  • C++实现添加括号的不同方式
    本篇内容介绍了“C++实现添加括号的不同方式”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!添加括号的不同方式Given a string o...
    99+
    2023-06-20
  • C++实现LeetCode(241.添加括号的不同方式)
    [LeetCode] 241. Different Ways to Add Parentheses 添加括号的不同方式 Given a string of numbers and o...
    99+
    2024-04-02
  • C++实现LeetCode(159.最多有两个不同字符的最长子串)
    [LeetCode] 159. Longest Substring with At Most Two Distinct Characters 最多有两个不同字符的最长子串 Given...
    99+
    2024-04-02
  • java算法入门之有效的括号删除有序数组中的重复项实现strStr
    目录1、LeetCode 20.有效的括号题目小编菜解思路及算法大神解法2、LeetCode 26.删除有序数组中的重复项题目小编菜解初版小编菜解改进版思路及算法大神解法3、Leet...
    99+
    2024-04-02
  • win7 c盘清理最有效的方法是什么
    这篇“win7 c盘清理最有效的方法是什么”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“win7 c盘清理最有效的方法是什么...
    99+
    2023-07-01
  • sqlserver查找括号()中字符串内容的方法实现
    目录PATINDEX()函数charindex()函数SUBSTRING函数假如有一张学生表,表中学生姓名是学生的中文名(英文名),如何获取括号中的英文名称。 需要用到两个SQL函数的配合,一个是PATINDEX()函...
    99+
    2023-05-16
    sqlserver查找括号中字符串 sqlserver查找字符串
  • C++实现无重复字符的最长子串
    目录题目及要求:提示:原创代码:代码思路:题目及要求: 给定一个字符串 s ,请你找出其中不含有重复字符的 最长子串 的长度。 提示: 0 <= s.length <...
    99+
    2024-04-02
  • C#算法怎么实现无重复字符的最长子串
    这篇文章主要介绍“C#算法怎么实现无重复字符的最长子串”,在日常操作中,相信很多人在C#算法怎么实现无重复字符的最长子串问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”C#算法怎么实现无重复字符的最长子串”的疑...
    99+
    2023-06-26
  • C/C++关于实现CAN信号的获取方法
    目录CAN基础知识CAN 信号C语言涉及到知识CAN基础知识 标准的CAN 数据为8字节,即64位,但是CAN FD的最大数据可为64字节,为512位,其中的帧ID分为标准帧和扩展帧...
    99+
    2023-02-03
    C++ CAN信号 C++ CAN信号获取 C语言CAN信号
  • C语言实现求最大公约数的方法有哪些
    这篇文章主要介绍C语言实现求最大公约数的方法有哪些,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!题目描述求任意两个正整数的最大公约数问题分析最大公因数,也称最大公约数、最大公因子,指两个或多个整数共有约数中最大的一个...
    99+
    2023-06-22
  • C++实现寻找旋转有序数组的最小值的方法
    本篇内容介绍了“C++实现寻找旋转有序数组的最小值的方法”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!寻找旋转有序数组的最小值Suppose...
    99+
    2023-06-20
  • C++中怎么利用LeetCode实现最多有两个不同字符的最长子串
    本篇文章给大家分享的是有关C++中怎么利用LeetCode实现最多有两个不同字符的最长子串,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。[LeetCode] 159. Long...
    99+
    2023-06-20
  • C++实现可排序最大块数的方法
    这篇“C++实现可排序最大块数的方法”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“C++实现可排序最大块数的方法”文章吧。M...
    99+
    2023-06-19
  • C#转义字符双引号的实现方法
    这篇文章主要讲解了“C#转义字符双引号的实现方法”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C#转义字符双引号的实现方法”吧!转义字符 \◆一种特殊的字符常量;◆以反斜线"\&q...
    99+
    2023-06-17
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作