1.火车站开饭店

最大独立集裸题

 #include<iostream>
 #include<cstdio>
 #include<cstdlib>
 #include<cstring>
 #include<algorithm>
 #include<string>
 #define N 200000+20
 using namespace std;
 ];
 ;
 void link(int x,int y){
     nxt[++tot]=head[x];
     to[tot]=y;
     head[x]=tot;
 }
 void dfs(int x,int fa){
     dp[x][]=a[x];//0为在独立集里
     dp[x][]=;//1为不在
     for (int i=head[x];i;i=nxt[i]){
         if (to[i]==fa) continue;
         dfs(to[i],x);
         dp[x][]+=dp[to[i]][];
         dp[x][]+=max(dp[to[i]][],dp[to[i]][]);
     }
 }
 int main(){
     scanf ("%d",&n);
     ;i<=n;++i) scanf ("%d",&a[i]);
     int x,y;
     ;i<n;++i){
         scanf ("%d%d",&x,&y);
         link(x,y),link(y,x);
     }
     dfs(,);
     printf (][],dp[][]));
     ;
   }

2.树的最小染色

考题 当时只打了两个状态 居然用我神奇的调试功力搞了10分?

考完之后愣是想了好久才想通 好像是最小支配集

#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<algorithm>
#define maxn 300000
#define INF 10000100
using namespace std;
,root=,sum,f[maxn][],ans=,g[maxn],sz[maxn];
void link(int x,int y)
{
    nxt[++tot]=head[x];
    to[tot]=y;
    head[x]=tot;
}
void dfs(int x)
{
    if (!sz[x])//0 靠爸爸 1 靠儿子 2 靠自己
    {
        f[x][]=,f[x][]=INF>>,f[x][]=v[x];
        return ;
    }
        ,fl=;
    for (int i=head[x];i;i=nxt[i])
    {
        int t=to[i];
        dfs(t);
        f[x][]+=min(f[t][],min(f[t][],f[t][]));
        f[x][]+=f[t][];
        ]>=f[t][]) fl=,s2+=f[t][];
        ],s1=min(s1,f[t][]-f[t][]);
    }
    f[x][]+=v[x];
    f[x][]=s2;
    ]+=s1;
}
int main()
{
    int n;
    scanf ("%d",&n);
    ;i<=n;++i)
    {
        int x,y,z,k;
        scanf ("%d%d%d",&x,&y,&z);
        v[x]=y,sz[x]=z;
                ;j<=z;++j)
        {
            scanf ("%d",&k);
            link(x,k);
            g[k]=;
        }
    }
    ;i<=n;++i) if (!g[i]) root=i;
    dfs(root);
    cout<<min(f[root][],f[root][]);
    ;
}    

3.POJ 3659 Cell Phone Network

最小支配集  模板题 另外我发现我真的很喜欢打靠爸爸靠儿子还是靠自己之类的话23333

 #include<iostream>
 #include<cstdio>
 #include<cstdlib>
 #include<cstring>
 #include<algorithm>
 #include<string>
 #define ll long long
 #define db double
 #define N 20000
 #define inf 1000000000
 using namespace std;
 ];
 ;
 void link(int x,int y){
     nxt[++tot]=head[x];
     to[tot]=y;
     head[x]=tot;
 }
 void dfs(int x,int fa){
     dp[x][]=,dp[x][]=,dp[x][]=;//0属于 1靠儿子 2靠父亲
     ,q=inf;
     for (int i=head[x];i;i=nxt[i]){
         int t=to[i];
         if (t==fa) continue;
         dfs(t,x);
         dp[x][]+=min(dp[t][],min(dp[t][],dp[t][]));
         ]!=inf&&dp[x][]!=inf) dp[x][]+=dp[t][];
         ]=inf;
         ]>=dp[t][]) dp[x][]+=dp[t][],fl=t;
         ]+=dp[t][];
         q=min(q,dp[t][]-dp[t][]);
     }
     ]+=q;
     ])  dp[x][]=inf;
 }
 int main(){
     int n;
     scanf ("%d",&n);
     int x,y;
     ;i<n;++i){
         scanf ("%d%d",&x,&y);
         link(x,y),link(y,x);
     }
     dfs(,);
     printf (][],dp[][]));
     ;
   }

4.POJ 2152 消防站

神题啊qwq 怎么推的出(瘫

围观了一下dalao的论文感觉很有道理又觉得不是很明白

后来翻到:http://blog.csdn.net/loi_dqs/article/details/50878337 在吸取了论文部分内容的基础上很快就明白了

 #include<iostream>
 #include<cstdio>
 #include<cstdlib>
 #include<cstring>
 #include<algorithm>
 #include<string>
 #include<queue>
 #include<vector>
 #define ll long long
 #define db double
 #define N 5000
 using namespace std;
 ;
 int w[N],d[N],k[N],de[N][N],ans[N],f[N][N];
 struct hh{
     int to,nxt,w;
 }b[N];
 int head[N];
 void link(int x,int y,int w){
     b[++tot].nxt=head[x];
     b[tot].to=y;
     b[tot].w=w;
     head[x]=tot;
 }
 void dis(int x,int y,int fa,int di){
     de[x][y]=min(de[x][y],di);
     for (int i=head[y];i;i=b[i].nxt){
         int v=b[i].to;
         if (v==fa) continue;
         dis(x,v,y,di+b[i].w);
     }
 }
 void dp(int x,int fa){
     for (int i=head[x];i;i=b[i].nxt){
         int t=b[i].to;
         if (t==fa) continue;
         dp(t,x);
     }
     ;i<=n;++i){
         if (de[x][i]>d[x]) continue;
         f[x][i]=w[i];
         for (int j=head[x];j;j=b[j].nxt){
             int k=b[j].to;
             if (k==fa) continue;
             f[x][i]+=min(f[k][i]-w[i],ans[k]);
         }
         ans[x]=min(ans[x],f[x][i]);
     }
 }
 int main(){
     scanf ("%d",&n);
     ;i<=n;++i) scanf ("%d",&w[i]);
     ;i<=n;++i) scanf ("%d",&d[i]);
     int x,y,z;
     ;i<n;++i){
         scanf ("%d%d%d",&x,&y,&z);
         link(x,y,z);link(y,x,z);
     }
     memset(f,0x3f,sizeof(f));
     memset(de,0x3f,sizeof(de));
     memset(ans,0x3f,sizeof(ans));
     ;i<=n;++i) dis(i,i,,);
     dp(,);
     printf (]);
     ;
   }

UPD        2017_07_12

连考两天树形dp我都在鬼混 感觉很不好意思TAT(之前可能是白学了)(那个白学 不是那个白学)

发现了一点小套路?

感觉这一类题经常可以用两个dp的数组分别搞然后分情况转移合并 这样思路比较简单

也可以设三个左右状态互相转移 实现起来会更清爽qwq

然后好像经常设的都是N×M之类的 一般要数据范围别太大才能玩吧

状态大多跟父节点 子节点 子树的个数 在不在某状态中 一类有关qwq

还需多多领悟啊= =

树形dp系列的更多相关文章

  1. HDU 4514 湫湫系列故事——设计风景线(并查集+树形DP)

    湫湫系列故事——设计风景线 Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 65535/32768 K (Java/Others) To ...

  2. HDU 4514 - 湫湫系列故事——设计风景线 - [并查集判无向图环][树形DP求树的直径]

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4514 Time Limit: 6000/3000 MS (Java/Others) Memory Li ...

  3. 树形DP水题系列(1):FAR-FarmCraft [POI2014][luogu P3574]

    题目 大意: 边权为1 使遍历树时到每个节点的时间加上点权的最大值最小 求这个最小的最大值 思路: 最优化问题 一眼树形DP 考虑状态设立 先直接以答案为状态 dp[u] 为遍历完以u为根的子树的答案 ...

  4. 【二叉树-最长路径系列(任意路径)】直径、最长同值路径、 最大路径和(DFS、树形DP)

    总述 这类题目都是求一个最长路径,这个路径可以不经过根节点. 使用dfs(即递归地遍历树)的方法.维护一个全局最长路径max作为最终结果,而递归方法dfs返回的是含根节点的最长路径.(若不使用全局变量 ...

  5. 【BZOJ-1864】三色二叉树 树形DP

    1864: [Zjoi2006]三色二叉树 Time Limit: 1 Sec  Memory Limit: 64 MBSubmit: 659  Solved: 469[Submit][Status] ...

  6. 代码风格与树形DP

    Streaming很惨,不过因为比赛之间没有提交过就没掉(或掉了)rating.第二题是一个树形DP,但是我都在想第一题了,简直作死. 看着神犇的代码我也是醉了...各种宏,真是好好写会死系列. 看到 ...

  7. 2017 Multi-University Training Contest - Team 1 1003&&HDU 6035 Colorful Tree【树形dp】

    Colorful Tree Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Others)T ...

  8. hdu 4514 并查集+树形dp

    湫湫系列故事——设计风景线 Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 65535/32768 K (Java/Others)Tot ...

  9. 树形DP——动态规划与数据结构的结合,在树上做DP

    本文始发于个人公众号:TechFlow,原创不易,求个关注 今天是算法与数据结构的第15篇,也是动态规划系列的第4篇. 之前的几篇文章当中一直在聊背包问题,不知道大家有没有觉得有些腻味了.虽然经典的文 ...

随机推荐

  1. 《HelloGitHub》第 20 期

    前言 HelloGitHub 项目已经累积到 3k+ Stars.本项能够走到今天,帮助到越来越多的人.少不了热爱开源.不断为本项目贡献项目的小伙伴们. 贡献者列表 很多人都有想法,付诸于行动在少数, ...

  2. 用python实现一个简单的词云

    对于在windows(Pycharm工具)里实现一个简单的词云还是经过了几步小挫折,跟大家分享下,如果遇到类似问题可以参考: 1. 导入wordcloud包时候报错,当然很明显没有安装此包. 2. 安 ...

  3. 【微软大法好】VS Tools for AI全攻略(3)

    接着上文,现在我们需要一种穷人的方法来搭建好Azure虚拟机. 思路很简单,因为AI组件的原理其实是传送了script文件和命令上去,那么我们这个虚拟机只要做好了所有的配置,那么我们就可以将它当作深度 ...

  4. 多线程编程 - PHP 实现

    * { color: #3e3e3e } body { font-family: "Helvetica Neue", Helvetica, "Hiragino Sans ...

  5. 简单模板view调用

    $this->display();//模板名称与当前控制器.当前操作方法的名称不一致 $this->display();//调用当前控制器对应目录指定名称的模板 $this->dis ...

  6. Oracle 每天自动生成AWR报告

    经验丰富的老员工希望能够每天为数据库生成1个AWR报告,以便于后期分析数据库的性能变化,手动生成太麻烦,查了一下资料,发现可以自动生成,过程如下. 数据库环境:11gR2 RAC(双节点) AWR报告 ...

  7. Netty4 学习笔记之二:客户端与服务端心跳 demo

    前言 在上一篇Netty demo 中,了解了Netty中的客户端和服务端之间的通信.这篇则介绍Netty中的心跳. 之前在Mina 中心跳的使用是通过继承 KeepAliveMessageFacto ...

  8. svn服务器的搭建与使用二

    转载出处 上一篇介绍了VisualSVN Server和TortoiseSVN的下载,安装,汉化.这篇介绍一下如何使用VisualSVN Server建立版本库,以及TortoiseSVN的使用. 首 ...

  9. 调用WebService获取数据

    以下调用方法,以调用苏州天气接口为例. 一.后台请求服务 方法一.C#后台,通过构建Soap请求接口数据 //获取天气详细信息 public JsonResult GetWeatherDetails( ...

  10. android boot.img

    android在启动时uboot推断有没有组合健按下或者cache分区的升级文件来决定进入哪个系统(可能还有别的推断方式) 有组合健按下或者cache分区有升级文件,则载入recovery.img进入 ...