设为首页 加入收藏

TOP

九度笔记之 1342:寻找最长合法括号序列II(25分)
2014-11-23 21:42:17 来源: 作者: 【 】 浏览:6
Tags:笔记 1342 寻找 最长 合法 括号 序列 25分

题目1342:寻找最长合法括号序列II(25分)

时间限制:1 秒
内存限制:32 兆
特殊判题:否
提交:527
解决:216

题目描述:
假如给你一个由’(‘和’)’组成的一个随机的括号序列,当然,这个括号序列肯定不能保证是左右括号匹配的,所以给你的任务便是去掉其中的一些括号,使得剩下的括号序列能够左右括号匹配且长度最长,即最长的合法括号序列。
输入:
测试数据包括多个,每个测试数据只有一行,即一个随机的括号序列,该括号序列的长度保证不超过106。
输出:
对于每个测试案例,输出一个整数,表示最后剩下的最长合法括号序列长度。
样例输入:
(())()
(()样例输出:
6
2算法分析

一句话,从左到右看能找到几对括号。

利用Lnum表示在当前位置已经找个几个单身的‘(’,

当遇到‘(’,Lnum++;

当遇到‘)’,如果Lnum>0,表示前面有单身的‘(’, 当前的‘)’和 前面的一个'('结为一对,少了一个单身的'(', 所以Lnum减1。 又因为新增加了一对‘(’,‘)’,所以maxLen+=2;

另外一个 最长合法括号序列题,不过算法相差很大。 见九度笔记之 1337:寻找最长合法括号序列

源程序

//============================================================================
// Name        : judo1342new.cpp
// Author      : wdy
// Version     :
// Copyright   : Your copyright notice
// Description : Hello World in C++, Ansi-style
//============================================================================
//similar to 1337
//similar to 1260
#include 
using namespace std;
 
void getMaxLen(std::string &s){
    std::string::size_type len = s.size();
    std::string::size_type pos = 0;
 
    int Lnum = 0;
    //int Rnum = 0;
    int maxLen  = 0;
    for(pos = 0;pos0){
            --Lnum;
            maxLen+=2;
        }
    }//for
    std::cout<>s){
        getMaxLen(s);
    }
}
int main() {
    judo();
    //cout << "!!!Hello World!!!" << endl; // prints !!!Hello World!!!
    return 0;
}
 
/**************************************************************
    Problem: 1342
    User: KES
    Language: C++
    Result: Accepted
    Time:220 ms
    Memory:3052 kb
****************************************************************/

】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇HDU 4619 Warm up 2 (2013 多校.. 下一篇HDU 2058 The sum problem

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容:

·Redis on AWS:Elast (2025-12-27 04:19:30)
·在 Spring Boot 项目 (2025-12-27 04:19:27)
·使用华为开发者空间 (2025-12-27 04:19:24)
·Getting Started wit (2025-12-27 03:49:24)
·Ubuntu 上最好用的中 (2025-12-27 03:49:20)