间隔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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • FindWindowEx的用法「建议收藏」

    FindWindowEx的用法「建议收藏」FindWindowEx完整定义如下:HWNDFindWindowEx(HWNDhwndParent,//父窗口句柄HWNDhwndChildAfter,//开始的子窗口句柄,这个参数很有用LPCTSTRlpszClass,//类名LPCTSTR

    2022年5月31日
    39
  • java 配置环境变量[通俗易懂]

    java 配置环境变量[通俗易懂]1.情景展示虽然,我们在实际开发过程中,无论是通过idea、eclipse、myeclipse来完成java项目的开发,通过这些工具来帮助我们实现由java文件编译成class文件,但是,一旦脱离了

    2022年7月3日
    20
  • 项目启动会应该注意的几点

    项目启动会应该注意的几点

    2022年1月25日
    37
  • 大数据_03【大数据基础知识】

    大数据_03【大数据基础知识】大数据_0301大数据概述02什么是大数据?(BigData)03传统数据与大数据的对比04大数据的特点4.1传统数据与大数据处理服务器系统安装对比4.2大数据下服务器系统安装![在这里插入图片描述](https://img-blog.csdnimg.cn/20201006090915426.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV

    2022年5月4日
    42
  • STL 源代码分析 算法 stl_algo.h — merge

    STL 源代码分析 算法 stl_algo.h — merge

    2022年1月16日
    40
  • 磁盘显示没有初始化找到数据法子[通俗易懂]

    磁盘显示没有初始化找到数据法子[通俗易懂]没有初始化是因为分区表损坏了,导致移动硬盘出现没有初始化。磁盘显示没有初始化找到数据法子没有初始化是因为分区表损坏了,导致移动硬盘出现没有初始化。磁盘显示没有初始化找到数据法子工具/软件:光明数据恢复软件步骤1:程序打开后,直接双击需要恢复的物理盘,没有初始化需要从磁盘恢复文件。步骤2:坐等软件扫描完成一般需要几分钟到半个小时,稍微耐心等下即可。步骤3:打钩所有需要恢复的文件,然后点右上角的保存,《另存为》按钮,将打钩的文件拷贝出来。步骤4:最后一步只需要等程序将文件复制完成就可以了

    2022年9月21日
    0

发表回复

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

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