【ACM】算法题-序列的深度(c++)(栈)(STL)(动态规划)(图论)

序列的深度

题目描述

一个合法的括号匹配序列有以下定义:
1、空串"“是一个合法的括号匹配序列
2、如果"X"和"Y"都是合法的括号匹配序列,“XY"也是一个合法的括号匹配序列
3、如果"X"是一个合法的括号匹配序列,那么”(X)“也是一个合法的括号匹配序列
4、每个合法的括号序列都可以由以上规则生成。
例如: “”,”()”,“()()”,"((()))“都是合法的括号序列
对于一个合法的括号序列我们又有以下定义它的深度:
1、空串”"的深度是 0
2、如果字符串"X"的深度是 x,字符串"Y"的深度是 y,那么字符串"XY"的深度为 max(x,y)

3、如果"X"的深度是 x,那么字符串"(X)"的深度是 x+1

例如: "()()()“的深度是 1,”((()))"的深度是 3。牛牛现在给你一个合法的括号序列,需要你计算出其深度
输入:
多组输入。
输入包括一个合法的括号序列 s,s 长度 length(2 ≤ length ≤ 50),序列中只包含’(‘和’)'。
输出:
输出一个正整数,即这个序列的深度。
样例输入

(())

样例输出

2

题解

题解一(栈)

第一个较好的思路,直接使用栈,用循环来判断进栈与出栈并标记序列的深度:
#include<bits/stdc++.h>

using namespace std;
#define endl '\n'
using ll=long long;

int main() {
    ios::sync_with_stdio(false);
    cin.tie(nullptr);
    cout.tie(nullptr);
    string s;
    while (cin >> s) {//多组输入
        stack<int> S;
        int d = 0, maxd = 0;
        for (int i = 0; i < s.size(); i++) {
            if (s[i] == '(') {
                S.push(s[i]);//‘(’进栈
                maxd = max(maxd, (int) S.size());//不停更换最大序列深度
            } else {
                S.pop();//出栈
            }
        }
        cout << maxd << endl;
    }
    return 0;
}

题解二(动态规划)

第二个方法是利用动态规划来实现,同样解决问题。
#include<bits/stdc++.h>

using namespace std;
#define endl '\n'
using ll=long long;

int main() {
    ios::sync_with_stdio(false);
    cin.tie(nullptr);
    cout.tie(nullptr);
    for (string s; cin >> s;) {
        vector<int> dp(s.size(), 1);
        for (int i = 1; i < s.size(); i++) {
            if (s[i] == '(')dp[i] = s[i - 1] == '(' ? dp[i - 1] + 1 : dp[i - 1];
            else dp[i] = s[i - 1] == '(' ? dp[i - 1] : dp[i - 1] - 1;
        }
        cout << *max_element(dp.begin(), dp.end()) << endl;
    }
    return 0;
}
注意动态规划里判断句内的方程要思考并完善是一个合法的序列内增加长度,另外序列重新记。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值