題目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 <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 ****************************************************************/