程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> C++ >> C++入門知識 >> 九度筆記之 1342:尋找最長合法括號序列II(25分)

九度筆記之 1342:尋找最長合法括號序列II(25分)

編輯:C++入門知識

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

 

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved