首页 > 试题广场 >

括号匹配方案

[编程题]括号匹配方案
  • 热度指数:291 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 32M,其他语言64M
  • 算法知识视频讲解
合法的括号匹配序列被定义为:
1. 空串""是合法的括号序列
2. 如果"X"和"Y"是合法的序列,那么"XY"也是一个合法的括号序列
3. 如果"X"是一个合法的序列,那么"(X)"也是一个合法的括号序列
4. 每个合法的括号序列都可以由上面的规则生成
例如"", "()", "()()()", "(()())", "(((())))"都是合法的。 东东现在有一个合法的括号序列s,一次移除操作分为两步:
1. 移除序列s中第一个左括号
2. 移除序列s中任意一个右括号.保证操作之后s还是一个合法的括号序列
东东现在想知道使用上述的移除操作有多少种方案可以把序列s变为空
如果两个方案中有一次移除操作移除的是不同的右括号就认为是不同的方案。
例如: s = "()()()()()",输出1, 因为每次都只能选择被移除的左括号所相邻的右括号.
s = "(((())))",输出24, 第一次有4种情况, 第二次有3种情况, ... ,依次类推, 4 * 3 * 2 * 1 = 24

输入描述:
输入包括一行,一个合法的括号序列s,序列长度length(2 ≤ length ≤ 20).


输出描述:
输出一个整数,表示方案数
示例1

输入

(((())))

输出

24
#include<bits/stdc++.h>
using namespace std;
int main(){
    string s;
    while(cin>>s){
        int ans=1;
        int i;
        while(s.size()){
            i = s.find_first_of(")");
            ans *= i;
            s.erase(i,1);
            s.erase(0,1);
        }
        cout << ans << endl;
    }
    return 0;
}
发表于 2022-03-25 14:29:37 回复(0)
#include <stdio.h>
#include <stdlib.h>
#include <string>
#include <vector>
#include <iostream>
using namespace std;
int main()
{
    string s;
    cin >> s;
    vector<int> cout_left, cout_right;
    for(int i = 0; i < s.size(); i++)
    {
        if(s.at(i) == '(')
        {
            cout_left.push_back(i);
        }
        else
        {
            cout_right.push_back(i);
        }
    }
    vector<int> num;
    for(int i=0; i<cout_left.size(); i++)
    {
        int anum = 1;
        int begin_idx, end_idx;
        begin_idx = cout_left.at(i);
        end_idx = cout_right.at(i);
        for(int j=begin_idx+1; j< end_idx; j++)
        {
            if(s.at(j)==')')
            {
                anum++;
            }
        }
        num.push_back(anum);
    }
    int result = 1;
    for(int i=0; i<num.size(); i++)
    {
        result *= num.at(i);
    }
    cout<<result<<endl;
    system("pause");
    return 0;
}
发表于 2018-09-09 18:39:15 回复(0)
两个目标位一个X一个Y 向前向后移动 寻找公共区域 直到  ANS时候找到 输出即可
发表于 2018-06-30 17:45:11 回复(0)