题目1342:寻找最长合法括号序列II(25分)
-
题目描述:
- 假如给你一个由’(‘和’)’组成的一个随机的括号序列,当然,这个括号序列肯定不能保证是左右括号匹配的,所以给你的任务便是去掉其中的一些括号,使得剩下的括号序列能够左右括号匹配且长度最长,即最长的合法括号序列。
-
输入:
- 测试数据包括多个,每个测试数据只有一行,即一个随机的括号序列,该括号序列的长度保证不超过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
****************************************************************/