涂色PAINT

[CQOI2007]涂色PAINT

https://ac.nowcoder.com/acm/problem/19909

区间dp
用dp[i][j]表示区间i~j的最小涂色次数
如果i和j的颜色一样,就可以转化为dp[i][j-1]或者dp[i+1][j]
如果不一样,就枚举i和j中间的每一个,计算dp[i][k]+dp[k+1][j]的值

#include <cstdio>
#include <iostream>
#include <algorithm>
#include <cstring>
#include <string>
#include <stack>
#include <queue>
#include <cmath>
#define ll long long
#define pi 3.1415927
#define inf 0x3f3f3f3f
#define mod 1000000007
using namespace std;
#define _int __int128_t
int n,m;
int dp[1005][1005];
string s;
int main ()
{
    int T,i,t,j,k,p,sum=0;
    cin>>s;
    int l=s.length();
    memset(dp,inf,sizeof(dp));
    for(i=0;i<=l;++i)
        dp[i][i]=1;
    for(i=2;i<=l;++i){
        for(j=0;j<=l-i;j++){
            k=j+i-1;
            if(s[j]==s[k])
                dp[j][k]=min(dp[j][k-1],dp[j+1][k]);
            else{
                for(int u=j;u<k;++u)
                    dp[j][k]=min(dp[j][u]+dp[u+1][k],dp[j][k]);
            }
        }
    }
    cout<<dp[0][l-1]<<endl;

    return 0;
}
全部评论

相关推荐

05-26 22:25
门头沟学院 Java
Java小肖:不会是想叫你过去把你打一顿吧,哈哈哈
点赞 评论 收藏
分享
06-08 22:25
门头沟学院 Java
从零开始的转码生活:这hr不会打开手机不分青红皂白给所有人群发这句话,过一会再给所有人再发一遍,这肯定会有重复的,不管,再过一会再发一遍
点赞 评论 收藏
分享
找个工作&nbsp;学历是要卡的&nbsp;要求是高的&nbsp;技能不足是真的&nbsp;实习经验是0的&nbsp;简历无处可写是事实的&nbsp;钱不好赚是真的&nbsp;想躺平又不敢躺&nbsp;也不甘心躺&nbsp;怕自己的灵感和才华被掩埋甚至从未被自己发现&nbsp;又质疑自己是否真正有才华
码农索隆:你现在啊,你心里都明白咋回事,但是你没办法改变现状,一想到未来,你又没有信心狠下心来在当下努力。 得走出这种状态,不能一直困在那里面,哪不行就去提升哪,你一动不动那指定改变不了未来,动起来,积少成多才能越来越好
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务