1.树形dp

例题1

树上最长链

其实有两种方法,但为了简便,就只学了最通用的dp算法

我们考虑设dp[i][0/1]表示以i为根的最长路和次长路,然后拼接就行了

第二维0表示最长路,1表示次长路

if dp[i][0]<dp[son][0] then dp[i][1]=dp[i][0],dp[i][0]=dp[son][0]

if dp[i][0]>dp[son][0] && dp[i][1]<dp[son][0] then dp[i][1]=dp[son][0]

就可以了

例题2

codevs1378

有n节课可以选,每节课有至多一个前置课程,和这节课的学分,问如果只能选m节课,最多有多少学分。

这是一道类似于树形背包的dp

dp么,需要记录所有可行状态

考虑设dp[i][j]在以i为根的子树中选除j个课程的最大价值

每次新增一个儿子,就相当于新增加一个多重背包中的物品。此处暴力枚举就可以了,时间复杂度O(n^3)

#include<cstdio>
#include<algorithm>
#include<iostream>
using std::max;
using std::min;
const int maxn=310;
struct node
{
int point;
int nxt;
};
node line[maxn<<1];
int s[maxn];
int head[maxn],tail;
int ind[maxn];
int f[maxn][maxn];
int siz[maxn];
int n,m;
void add(int a,int b)
{
line[++tail].point=b;
line[tail].nxt=head[a];
head[a]=tail;
}
void dfs(int now)
{
siz[now]=1;
f[now][1]=s[now];
for(int i=head[now];i;i=line[i].nxt)
{
dfs(line[i].point);
for(int j=siz[now]+siz[line[i].point];j>=2;j--)
for(int k=1;k<=min(siz[line[i].point],j-1);k++)
f[now][j]=max(f[now][j],f[now][j-k]+f[line[i].point][k]);
siz[now]+=siz[line[i].point];
}
}
int main()
{
scanf("%d%d",&n,&m);
int dat;
for(int i=1;i<=n;i++)
{
scanf("%d%d",&dat,&s[i]);
add(dat,i); }
dfs(0);
printf("%d",f[0][m+1]);
}

例题3

hdu4679

给定一颗树,每条边有一个权值w,问切掉哪条边之后,分成的两颗树的较大的直径*切掉边的权值最小?如果存在多条边使得结果相同,输出边id最小的。

考虑枚举切哪一条边,若不在整棵树的直径上,处理就很好处理

然后我们考虑如果在直径上呢? 考虑从直径的左右两端点分别为根做一次dp,然后每次切边。将一棵树分成两棵树,这样就可以在o(1)时间内算出分离后两颗子树的直径了

预处理多么重要呀~~

例题4

codeforces219d

给一棵树,每条边有方向,改变一条边方向的代价是1.

对于一个点,如果选它为根,那么需要把方向不对的边改变方向(都变成深度小的点指向深度大的点)。

问选一个点为根的最小代价。和选哪些点的代价是这个数字。

其实这道题,如果看过平衡树中的rotate操作,其实不难。因为一次换根的时间是O(1)的

然后先选出一个点来,算出其所需次数,然后将其他点作为根试一次,然后就是O(n)的时间复杂度


例题4

bzoj1040

给一个环套树森林,求最大权独立集。(就是相邻的点不能同时选)

首先考虑dp一开始考虑做出决策的方法——枚举

首先每个点只有选与不选,是可以接受的。

然后我们考虑枚举环上的点,断环为链。再使用树形dp

但是我们在枚举的时候要枚举相邻的的两个点。防止不合法的情况

然后我还没有写出来QAQ


qbxt Day4的更多相关文章

  1. QBXT T15565 Day4上午道路分组

    有向并查集维护连通性 优化: vis数组表示能被节点1到达的点 显然,已经分在一个联通块中的点就没必要在用该点扩展了. #include<cstdio> #include<algor ...

  2. Qbxt 模拟赛 Day4 T2 gcd(矩阵乘法快速幂)

    /* 矩阵乘法+快速幂. 一开始迷之题意.. 这个gcd有个规律. a b b c=a*x+b(x为常数). 然后要使b+c最小的话. 那x就等于1咯. 那么问题转化为求 a b b a+b 就是斐波 ...

  3. 【五一qbxt】day4 数论知识

    这些东西大部分之前都学过了啊qwq zhx大概也知道我们之前跟着他学过这些了qwq,所以: 先讲新的东西qwq:(意思就是先讲我们没有学过的东西) 进制转换 10=23+21=1010(2) =32+ ...

  4. qbxt数学五一Day4

    目录 1. 随机试验 2. 概率 1. 平凡 2. 条件概率 3. 期望 习题 1 2 3 4 1. 随机试验 定义: 不能预先确知结果 试验之前可以预测所有可能结果或范围 可以在相同条件下重复实验 ...

  5. python_way,day4 内置函数(callable,chr,随机验证码,ord),装饰器

    python_way,day4 1.内置函数 - 下 制作一个随机验证码 2.装饰器 1.内置函数 - 下 callable() #对象能否被调用 chr() #10进制数字对应的ascii码表中的内 ...

  6. Spark菜鸟学习营Day4 单元测试程序的编写

    Spark菜鸟学习营Day4 单元测试程序的编写 Spark相比于传统代码是比较难以调试的,单元测试的编写是非常必要的. Step0:需求分析 在测试案例编写前,需完成需求分析工作,明确程序所有的输入 ...

  7. Spark Tungsten揭秘 Day4 内存和CPU优化使用

    Spark Tungsten揭秘 Day4 内存和CPU优化使用 今天聚焦于内存和CPU的优化使用,这是Spark2.0提供的关于执行时的非常大的优化部分. 对过去的代码研究,我们会发现,抽象的提高, ...

  8. Catalyst揭秘 Day4 analyzer解析

    Catalyst揭秘 Day4 analyzer解析 今天继续解析catalyst,主要讲一下analyzer,在sql语句的处理流程中,analyzer是在sqlparse的基础上,把unresol ...

  9. Kakfa揭秘 Day4 Kafka中分区深度解析

    Kakfa揭秘 Day4 Kafka中分区深度解析 今天主要谈Kafka中的分区数和consumer中的并行度.从使用Kafka的角度说,这些都是至关重要的. 分区原则 Partition代表一个to ...

随机推荐

  1. 突破Http协议

    突破Http协议 我到不先说什么Http什么的,对于HTTP的彻底理解是http是应用层的一个程序,就像我们写的诸多客户端和服务器模型,我们可能为了可靠,为了方便数据的解析,我们在数据包中其实就是结构 ...

  2. php之mongodb插入数据后如何返回当前插入记录ID

    <?php /** *插入记录 *参数: *$table_name:表名 *$record:记录 * *返回值: *成功:true *失败:false */ function insert($t ...

  3. 数据降维(Dimensionality reduction)

    数据降维(Dimensionality reduction) 应用范围 无监督学习 图片压缩(需要的时候在还原回来) 数据压缩 数据可视化 数据压缩(Data Compression) 将高维的数据转 ...

  4. FZU 2221—— RunningMan——————【线性规划】

     Problem 2221 RunningMan Accept: 17    Submit: 52Time Limit: 1000 mSec    Memory Limit : 32768 KB  P ...

  5. ubuntu遇到了 dpkg was interrupted, you must manually run 'dpkg..的问题

    dpkg was interrupted, you must manually run 'dpkg --configure -a' to correct the problem. E: _cache- ...

  6. [转].NET Core之Entity Framework Core 你如何创建 DbContext

    本文转自:http://www.cnblogs.com/tdws/p/5874212.html 本文版权归博客园和作者吴双共同所有,欢迎转载,转载和爬虫请注明博客园蜗牛原文地址 http://www. ...

  7. 在 Linux 上创建第一个 Service Fabric Java 应用程序

    先决条件 开始之前,请安装 Service Fabric SDK.Azure CLI,并在 Linux 开发环境中设置开发群集. 如果使用 Mac OS X,则可使用 Vagrant 在虚拟机中设置 ...

  8. 关于日常使用Azure MySQL中遇到的连接问题以及排查方法分享

    由于防火墙问题,TCP keep alive 问题,以及 MySQL 自身的参数问题这三个在使用中比较常见,所以今天就分享下自己找到的排查方法. 今天先聊一聊防火墙问题 大多数人在第一次创建 MySQ ...

  9. PCA (主成分分析)详解——转载 古剑寒

    转载地址:http://my.oschina.net/gujianhan/blog/225241 另外可以参考相关博文:http://blog.csdn.net/neal1991/article/de ...

  10. Redis的Publish/Subscribe

    Publish/Subscribe 从字面上理解就是发布(Publish)与订阅(Subscribe),在Redis中,你可以设定对某一个key值进行消息发布及消息订阅,当一个key值上进行了消息发布 ...