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


相关推荐

  • js正则表达式语法

    js正则表达式语法

    2021年12月31日
    43
  • 想发表文章在哪里发表_微信朋友圈怎么弄的置顶文字

    想发表文章在哪里发表_微信朋友圈怎么弄的置顶文字  因为博客中的文章已经越来越来了,为了便于文章检索,特整理本文,欢迎收藏!!!Java核心1.JDK8新特性Lambda表达式讲解接口新特性函数式接口方法引用Stream流Optional工具类介绍新的日期时间工具类介绍注解的增强2.Java核心Java集合核心内容之数组和链表Java集合核心内容之二叉树2-3-4树详解红黑树详解精讲红黑树删除操作剖析反射的本质3.设计模式3.1创建型模式  都是用来帮助我们创建对象的!模式地址单例模式ht

    2025年12月1日
    5
  • 绝对成交课程培训_成交的5大关键

    绝对成交课程培训_成交的5大关键影响力集团培训讲师孟昭春http://blog.sina.com.cn/mengzhaochun第一天下午一个思想:把自己能把握的事情把握就能实现把握不了的目标。1.孟老师从自身做法出发讲出:他下面的销售人员问他问题他从来不给答案,只是指墙(墙上有5问5答)。2.大客户特点:金额大、周期比较长、内部决策者多。3.用户的四个拒绝:我不需要、我不着急、我不相信、我没钱。(70%顾客…

    2025年8月3日
    3
  • 设备树传参中的platform device的匹配

    设备树传参中的platform device的匹配在高版本的Linux内核中使用了设备树进行传参,之前购买一块nanopi的板子使用的是linux4.11.2版本的内核(使用的友善之臂的Mainlinelinux)就是这种情况,并且使用设备树传参过后,原来硬编码在mach-xxx.c文件中的platformdevice全部都放入了设备树中,而原来使用name进行platformdevice和driver进行匹配的方式也发生了变化。以

    2022年7月24日
    16
  • Tomcat的下载及安装

    Tomcat的下载及安装一、Tomcat下载1、打开Tomcat官网,默认进入官网首页,官网地址为:https://tomcat.apache.org/2、左侧的导航栏可以看到Download(下载),以及最近相关版本的Tomcat(9、8、7…),这里选择的是Tomcat8,点击进入3、进入tomcat8的相关页面后会显示一些该版本的信息,可以忽略,鼠标下滑进行查找4、这里我们可以看到…

    2022年5月19日
    86
  • 使用VirtualBox + Vagrant打造统一的开发环境

    使用VirtualBox + Vagrant打造统一的开发环境

    2021年10月28日
    93

发表回复

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

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