热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

寻找最长合法括号子序列

本问题要求在给定的一串括号序列中,找到最长的合法括号子序列及其出现次数。合法括号子序列指的是所有左括号都能与唯一右括号配对,反之亦然。

问题概述:
给定一个长度为N的括号序列,该序列仅包含左括号'('和右括号')'。任务是确定此序列中最长的合法括号子序列,并统计满足此条件的子序列数量。合法括号子序列是指每个左括号都能找到对应的右括号进行匹配,且每个右括号也都有对应的左括号匹配。例如,((()))()() 是一个有效的括号序列,而(()))( 则不是一个有效序列。
要求计算最长合法括号子序列的长度及此类子序列的数量。

输入说明:
输入数据可能包含多组测试用例,每组测试用例包含两行:
第一行是一个整数N,表示括号序列的长度,N 的值不会超过10^6。
第二行是一个长度为N的字符串,由字符'(' 和 ')' 组成。

输出要求:
对于每一组测试用例,输出一行结果,该行包含两个整数,第一个整数表示最长合法括号子序列的长度,第二个整数表示具有该长度的子序列数量,两者之间以空格分隔。如果不存在合法的子序列,则输出0 1。

示例输入:

6
(())()
3
))(

示例输出:

6 1
0 1

import java.util.Stack;

public class BracketMatcher {
public static void findMaxValidBracketSequence(String input) {
Stack stack = new Stack<>();
int[] validBrackets = new int[input.length()];
int maxLength = 0;
int maxCount = 0;

for (int i = 0; i if (input.charAt(i) == '(') {
stack.push(i);
} else if (input.charAt(i) == ')') {
if (!stack.isEmpty()) {
int start = stack.pop();
validBrackets[start] = 1;
validBrackets[i] = 1;
}
}
}

// 计算连续的有效括号的最大长度
for (int i = 1; i if (validBrackets[i] > 0 && validBrackets[i - 1] > 0) {
validBrackets[i] += validBrackets[i - 1];
}
if (validBrackets[i] > maxLength) {
maxLength = validBrackets[i];
}
}

// 统计最大长度的有效括号序列数量
for (int length : validBrackets) {
if (length == maxLength) {
maxCount++;
}
}

System.out.println(maxLength == 0 ? "0 1" : maxLength + " " + maxCount);
}

public static void main(String[] args) {
findMaxValidBracketSequence("(()(()(");
findMaxValidBracketSequence("(())()");
findMaxValidBracketSequence("))(");
}
}

推荐阅读
  • OPPO黄页服务即将停止
    OPPO黄页服务因业务调整即将停止,用户需了解具体卸载路径及受影响的机型。 ... [详细]
  • 1函数1.1函数的定义  设xxx和yyy是两个变量,D,icod ... [详细]
  • PHP 编程疑难解析与知识点汇总
    本文详细解答了 PHP 编程中的常见问题,并提供了丰富的代码示例和解决方案,帮助开发者更好地理解和应用 PHP 知识。 ... [详细]
  • 深入理解OAuth认证机制
    本文介绍了OAuth认证协议的核心概念及其工作原理。OAuth是一种开放标准,旨在为第三方应用提供安全的用户资源访问授权,同时确保用户的账户信息(如用户名和密码)不会暴露给第三方。 ... [详细]
  • 极大似然估计(MLE)及其3D可视化解析
    本文详细介绍了极大似然估计(Maximum Likelihood Estimation, MLE)的推导过程,并通过3D可视化展示其在概率密度函数中的应用。我们将探讨如何利用MLE来估计参数,以及它在实际问题中的重要性。 ... [详细]
  • 2023 ARM嵌入式系统全国技术巡讲旨在分享ARM公司在半导体知识产权(IP)领域的最新进展。作为全球领先的IP提供商,ARM在嵌入式处理器市场占据主导地位,其产品广泛应用于90%以上的嵌入式设备中。此次巡讲将邀请来自ARM、飞思卡尔以及华清远见教育集团的行业专家,共同探讨当前嵌入式系统的前沿技术和应用。 ... [详细]
  • 本文介绍如何解决在 IIS 环境下 PHP 页面无法找到的问题。主要步骤包括配置 Internet 信息服务管理器中的 ISAPI 扩展和 Active Server Pages 设置,确保 PHP 脚本能够正常运行。 ... [详细]
  • Python 异步编程:深入理解 asyncio 库(上)
    本文介绍了 Python 3.4 版本引入的标准库 asyncio,该库为异步 IO 提供了强大的支持。我们将探讨为什么需要 asyncio,以及它如何简化并发编程的复杂性,并详细介绍其核心概念和使用方法。 ... [详细]
  • 探讨一个老旧 PHP MySQL 系统中,时间戳字段不定期出现异常值的问题及其可能原因。 ... [详细]
  • 国内BI工具迎战国际巨头Tableau,稳步崛起
    尽管商业智能(BI)工具在中国的普及程度尚不及国际市场,但近年来,随着本土企业的持续创新和市场推广,国内主流BI工具正逐渐崭露头角。面对国际品牌如Tableau的强大竞争,国内BI工具通过不断优化产品和技术,赢得了越来越多用户的认可。 ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • 郑州大学在211高校中的地位与排名解析
    本文将详细解读郑州大学作为一所位于河南省的211和双一流B类高校,在全国211高校中的地位与排名,帮助高三学生更好地了解这所知名学府的实力与发展前景。 ... [详细]
  • 深入理解 Oracle 存储函数:计算员工年收入
    本文介绍如何使用 Oracle 存储函数查询特定员工的年收入。我们将详细解释存储函数的创建过程,并提供完整的代码示例。 ... [详细]
  • 优化ASM字节码操作:简化类转换与移除冗余指令
    本文探讨如何利用ASM框架进行字节码操作,以优化现有类的转换过程,简化复杂的转换逻辑,并移除不必要的加0操作。通过这些技术手段,可以显著提升代码性能和可维护性。 ... [详细]
  • 本文总结了2018年的关键成就,包括职业变动、购车、考取驾照等重要事件,并分享了读书、工作、家庭和朋友方面的感悟。同时,展望2019年,制定了健康、软实力提升和技术学习的具体目标。 ... [详细]
author-avatar
沈巛小糖meimei昌策_247
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有