笔试 | 腾讯2021秋招笔试 技术研究&数据分析

文章首发于公众号面鲸,欢迎关注~
在这里插入图片描述

第一题
题目描述

现在给你一个只包含""括号的字符串,问你至少加多少个字符是合法的,对于字符串合法的定义为:

  • 字符串为空是合法的
  • 若字符串A合法,则字符串(A), [A]也是合法的
  • 若字符串A和字符串B均合法,则AB合法
输入
  • 第一行输入一个字符串s,保证只有题目要求的字符
  • 1 <= len(s) <= 200
输出
  • 输出最少需要添加几个字符可以构成合法的字符串
样例输入
样例输出
  • 1
样例输入
  • )(][][)(
样例输出
  • 3
分析
  • 如果只有一种括号的话就是leetcode921的原题
  • 有2种括号的话需要用DP去搞。我们先求出来通过添加字符,从i到j能构成的合法串的最短长度是多少。然后状态转移一波(分情况讨论)。
解法
#include <bits/stdc++.h>
using namespace std;

int dp[205][205];
int main(){
   
    string s;
    int i,j,k,p;
    while(cin>>s){
   
        memset(dp,0,sizeof(dp));
        if(s.size()==1){
   
            puts("1");
            continue;
        }
        for(i=0;i+1<s.size();i++){
   
            if((s[i]=='('&&s[i+1]==')')||(s[i]=='['&&s[i+1]==']'))
            dp[i][i+1]=2;
        }
        for(i=3;i<=s.size();i++){
   
            for(j=0;j+i-1<s.size();j++){
   
                k=j+i-1;
                dp[j][k]=max(dp[j][k],dp[j+1][k-1]);
                dp[j][k]=max(dp[j][k],max(dp[j+1][k],dp[j][k-1]));
                if((s[j]=='('&&s[k]==')')||(s[j]=='['&&s[k]==']')){
   
                    dp[j][k]=max(dp[j][k],dp[j+1][k-1]+2);
                }
                for(p=j+1;p<k;p++){
   
                    dp[j][k]=max(dp[j][k],dp[j][p]+dp[p+1][k]);
                }
            }
        }
        cout<<s.si
  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值