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. 第十八章:自定义splash screen、app icon和tab icon

    本文介绍如何自定义splash screen.app icon和tab icon. 1. 自定义splash screen和app icon 1.1 产生resources文件夹,启动命令行: ion ...

  2. MongoDB的MapReduce用法及php示例代码

    MongoDB虽然不像我们常用的mysql,sqlserver,oracle等关系型数据库有group by函数那样方便分组,但是MongoDB要实现分组也有3个办法: * Mongodb三种分组方式 ...

  3. 存储型xss调研

    概念 存储型XSS,持久化,代码是存储在服务器中的,如在个人信息或发表文章等地方,加入代码,如果没有过滤或过滤不严,那么这些代码将储存到服务器中,用户访问该页面的时候触发代码执行. 常见的xss攻击方 ...

  4. 【Shell】Shell脚本注意事项

    1.大部分的Linux系统默认配置bash.对比sh,bash扩展了一些命令和参数,并且保留对sh的一些兼容.除了bash.sh还有csh(语法类似C语言).tcsh(csh升级版).ash(适合低内 ...

  5. ul+js模拟select

    html   css .select_box{ float: left; } .select_box input{ width: 160px; height: 30px; text-align: ce ...

  6. 第七章--Java基础类库--与用户的互动

    1.命令行编译和运行java程序在notepad++中集成java编译运行命令 参考博客:http://blog.sina.com.cn/s/blog_84405af50101q7fn.html2与用 ...

  7. 关于Java中用Double型运算时精度丢失的问题

    注:转自 https://blog.csdn.net/bleach_kids/article/details/49129943 在使用Java,double 进行运算时,经常出现精度丢失的问题,总是在 ...

  8. Django的路由层(URLconf)

    URL配置(URLconf)就像Django 所支撑网站的目录.它的本质是URL与要为该URL调用的视图函数之间的映射表:你就是以这种方式告诉Django,对于客户端发来的某个URL调用哪一段逻辑代码 ...

  9. 如何修改Vue打包后文件的接口地址配置

    1.背景 常规的vue项目分为本地环境和生产环境,我们只要对 config 文件夹下的 dev.env.js 和 prod.env.js 做相应的配置即可.但是最近在做的项目中,涉及到私有化部署,就是 ...

  10. JSP初学者1

    native2ascii.exe 是 Java 的一个文件转码工具,是将特殊各异的内容 转为 用指定的编码标准文体形式统一的表现出来,它通常位于 JDK_home\bin 目录下, 安装好 Java ...