[置顶] 九度笔记之 1342:寻找最长合法括号序列II(25分)-给括号当红娘,解决最长合法字符串问题

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

时间限制:1 秒

内存限制:32 兆

特殊判题:

提交:527

解决:216

题目描述:
假如给你一个由’(‘和’)’组成的一个随机的括号序列,当然,这个括号序列肯定不能保证是左右括号匹配的,所以给你的任务便是去掉其中的一些括号,使得剩下的括号序列能够左右括号匹配且长度最长,即最长的合法括号序列。
输入:
测试数据包括多个,每个测试数据只有一行,即一个随机的括号序列,该括号序列的长度保证不超过10 6
输出:
对于每个测试案例,输出一个整数,表示最后剩下的最长合法括号序列长度。
样例输入:
(())()
(()
样例输出:
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 <iostream>
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;pos<len;pos++){
        if(s.at(pos)=='(')
            ++Lnum;
        else if(Lnum>0){
            --Lnum;
            maxLen+=2;
        }
    }//for
    std::cout<<maxLen<<std::endl;
}
 
void judo(){
    std::string s;
    while(std::cin>>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
****************************************************************/


你可能感兴趣的:([置顶] 九度笔记之 1342:寻找最长合法括号序列II(25分)-给括号当红娘,解决最长合法字符串问题)