codeforces 711C Coloring Trees(DP)

原创 2016年08月30日 12:15:18

题目链接:http://codeforces.com/problemset/problem/711/C

O(n^4)的复杂度,以为会超时的

思路:dp[i][j][k]表示第i棵数用颜色k涂完后beauty为j

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const ll inf=1e15;
int c[105];
int p[105][105];
ll dp[105][105][105];
int main()
{
    int n,m,b;
    scanf("%d%d%d",&n,&m,&b);
    for(int i=1;i<=n;i++)
        scanf("%d",&c[i]);
    for(int i=1;i<=n;i++)
    {
        for(int j=1;j<=m;j++)
            scanf("%d",&p[i][j]);
    }
    for(int i=1;i<=n;i++)
    {
        for(int j=1;j<=b;j++)
        {
            for(int k=1;k<=m;k++)
                dp[i][j][k]=inf;
        }
    }
    for(int i=1;i<=n;i++)
    {
        if(c[i])
        {
            for(int j=1;j<=b&&j<=i;j++)
            {
                int k=c[i];
                ll min1=inf,min2=inf;
                if(k>1&&j>1)
                    min1=*min_element(dp[i-1][j-1]+1,dp[i-1][j-1]+k);
                if(k<m&&j>1)
                    min2=*min_element(dp[i-1][j-1]+k+1,dp[i-1][j-1]+m+1);
                dp[i][j][k]=min(dp[i-1][j][k],min(min1,min2));
            }
        }
        else
        {
            for(int j=1;j<=b&&j<=i;j++)
            {
                for(int k=1;k<=m;k++)
                {
                    ll min1=inf,min2=inf;
                    if(k>1&&j>1)
                        min1=*min_element(dp[i-1][j-1]+1,dp[i-1][j-1]+k);
                    if(k<m&&j>1)
                        min2=*min_element(dp[i-1][j-1]+k+1,dp[i-1][j-1]+m+1);
                    dp[i][j][k]=p[i][k]+min(dp[i-1][j][k],min(min1,min2));
                }
            }
        }
    }
    ll ans=*min_element(dp[n][b]+1,dp[n][b]+m+1);
    if(ans<inf)
        printf("%I64d\n",ans);
    else
        printf("-1\n");
    return 0;
}


Codeforces Round #406 (Div. 2):C. Berzerk(记忆化搜索解决博弈问题)

C. Berzerk time limit per test 4 seconds memory limit per test 256 megabytes input standard in...
  • Jaihk662
  • Jaihk662
  • 2017年03月24日 15:23
  • 780

【打CF,学算法——五星级】CodeForces 478D (dp计数)

【CF简介】 提交链接:CF 478D 题面: D. Red-Green Towers time limit per test 2 seconds ...
  • David_Jett
  • David_Jett
  • 2016年07月12日 11:11
  • 502

概率dp入门的简单题(hdu 4405,牡丹江,codeforces)

最近学习了一下概率dp,感觉没有想象中的那么难。主要还是状态的转移方程的构建。 对于”求概率正推,求期望反推“这句话有了初步的理解。期望的意思是说你现在处在一个状态,还需要几步到达最终状态,这是一个期...
  • NK_test
  • NK_test
  • 2015年05月07日 23:58
  • 722

Codeforces 724E 最大流=最小割+dp求最小割

题意: 有n个城市,每个城市有p【i】的东西,可以在那个城市卖c【i】的东西,两两城市可以进行一次c的运送,只能从小的编号的往大的编号运。 问最多能卖多少货物。 思路: 最大流:建图,s到n个...
  • naipp
  • naipp
  • 2016年10月10日 17:49
  • 640

大坑!Codeforce DP题总结(持续更新)

个人非常喜欢做DP题,因为DP题有着特殊的数学美感持续不断吸引着我
  • rrtyui
  • rrtyui
  • 2014年09月22日 23:25
  • 2137

关于“缓存着色(cache coloring, page coloring)”技术的相关资料介绍

关于缓存着色(cache coloring)的相关资料
  • qianlong4526888
  • qianlong4526888
  • 2014年01月08日 17:22
  • 3371

【codeforces 732E】【贪心 map乱搞】

传送门:http://codeforces.com/contest/732/problem/E 描述: E. Sockets time limit per t...
  • guhaiteng
  • guhaiteng
  • 2016年10月22日 15:32
  • 532

codeforces上一种应对大测试数据debug方法

接触codeforces时间不长,也就参加了10场左右。之前有次比赛就出现了wa了一道题,在比赛结束后看测试数据log时,发现出错的那组用例是个超过一万行输入的情况,codeforces上的测试数据无...
  • qq_29070399
  • qq_29070399
  • 2017年02月03日 16:09
  • 745

关于codeforces比赛规则介绍(转载)

Codeforces 简称: cf(所以谈论cf的时候经常被误会成TX的那款游戏). 网址: codeforces.com   这是一个俄国的算法竞赛网站,由来自萨拉托夫州立大学、由Mike Mirz...
  • y990041769
  • y990041769
  • 2014年02月19日 08:41
  • 15506

python爬虫抓取codeforces分数

环境介绍 python 2.7.2 re 正则表达式库 urllib2 代码#coding:utf8 import sys import urllib2,redef getrating(name): ...
  • qscqesze
  • qscqesze
  • 2016年11月17日 22:02
  • 458
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:codeforces 711C Coloring Trees(DP)
举报原因:
原因补充:

(最多只允许输入30个字)