间隔DP基础 POJ2955——Brackets

间隔DP基础 POJ2955——Brackets

大家好,又见面了,我是全栈君,今天给大家准备了Idea注册码。

取血怒。first blood,第一区间DP,这样第一次没有以某种方式在不知不觉中下降~~~


题目尽管是鸟语。但还是非常赤裸裸的告诉我们要求最大的括号匹配数。DP走起~

dp[i][j]表示区间[i,j]的最大匹配数。那么最重要的状态转移方程就是:

dp[i][j]=max(dp[i][k]+dp[k+1][j])

对啦,要先初始化边界啊。两步走~:

memset(dp,0,sizeof dp);

if str[i]==str[i+1]   则:dp[i][i+1]=2       请看—->> 该字符串 ( [ ] [ ] [ )  非常好懂有木有



万恶的贴代码:

#include<iostream>
#include<cstring>
#include<cstdio>
#include<algorithm>
using namespace std;
int dp[110][110];
char s[110];
bool check(int i,int j)//推断是不是匹配的
{
    if(s[i]=='['&&s[j]==']') return true;
    if(s[i]=='('&&s[j]==')') return true;
    return false;
}
int main()
{
    while(scanf("%s",s)!=EOF){
        if(strcmp(s,"end")==0) break;
        int l=strlen(s);
        memset(dp,0,sizeof dp);
        for(int i=0;i<l;i++){                             //初始化
            if(check(i,i+1)){
                dp[i][i+1]=2;
            }
        }

        for(int p=3;p<=l;p++){                       //枚举区间长度
            for(int i=0;i<=l-p;i++){                //枚举区间起点
                int j=i+p-1;
                if(check(i,j)){
                    dp[i][j]=dp[i+1][j-1]+2;
                }
                for(int k=i;k<j;k++){           //将区间分成两段
                    dp[i][j]=max(dp[i][j],dp[i][k]+dp[k][j]);
                }
            }
        }
        cout<<dp[0][l-1]<<endl;
    }
    return 0;
}


       

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/116728.html原文链接:https://javaforall.net

(0)
上一篇 2022年1月16日 下午7:00
下一篇 2022年1月16日 下午7:00


相关推荐

  • 在Windows本地环境中部署OpenManus并接入Mistral模型的详细教程

    在Windows本地环境中部署OpenManus并接入Mistral模型的详细教程

    2026年3月15日
    2
  • bfp是什么电子元件_ad原理图器件旁边有红色波浪线

    bfp是什么电子元件_ad原理图器件旁边有红色波浪线ISPpipelineDBS:校准经过OBC之前不同像素暗电流的差值。因为器件原因,会存在暗电流,存在暗电流的情况下会导致偏色。OBC:sensor电路本身存在暗电流,没有光线的时候,像素会有输出,OBC减去暗电流,找到0基准。LensShadding:镜头阴影校正镜头是一个凸透镜,在接收光线时,成像较远时,会造成斜光束慢慢减少,图片中心较亮,四周比较暗。PGN:3A统计计算模块(计算awb、af、ae)UDM:利用颜色插值,光分为r,g,b三原色,g是亮度,通过g的插值,得到一下.

    2025年9月6日
    10
  • 科大讯飞2025年再发力:星火X1.5发布,AI多领域应用兑现技术红利

    科大讯飞2025年再发力:星火X1.5发布,AI多领域应用兑现技术红利

    2026年3月14日
    2
  • 一文搞定echarts地图轮播高亮⚡⚡

    一文搞定echarts地图轮播高亮⚡⚡前言这次给大家分享一下在工作中经常用到的 echarts 地图轮播高亮 技术栈用的是 vue2 x 相信效果大家已经清楚了那我们就开干吧 toDoList 简单的准备一个地图保存实例备用设置定时器设置鼠标移入移出事件 justdoit 准备一个地图首先准备一个简简单单的地图 因为我在广州所以就用广东省的地图啦 怎么在 echarts 使用地图我就不说了看看文档然后把对应的地图 json 导入就可以了 相信大家也会 对了有人问到我在哪里找地图

    2026年3月17日
    1
  • 智能称体脂称实现(基本原理解释篇)[通俗易懂]

    (本文均出于个人理解而写,仅用于学习和交流,某些过程可能不一定正确,希望各位提出意见进行交流,共同进步)项目简介前段时间接触到一个项目,类似于现在网上热卖的那种智能称,如下图所示

    2022年4月11日
    53
  • curl返回常见错误码

    curl返回常见错误码http://www.cnblogs.com/wainiwann/p/3492939.htmlCURLE_OK(0)所有罚款。继续像往常一样。CURLE_UNSUPPORTED_PROTOCOL(1)你的URL传递给libcurl的使用协议,这libcurl的不支持。支持可能是你没有使用一个编译时的选项,它可以是一个拼写错的协议字符串,或者只是一个协议的libcu

    2022年7月14日
    38

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号