qbxt Day4
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的更多相关文章
- QBXT T15565 Day4上午道路分组
有向并查集维护连通性 优化: vis数组表示能被节点1到达的点 显然,已经分在一个联通块中的点就没必要在用该点扩展了. #include<cstdio> #include<algor ...
- Qbxt 模拟赛 Day4 T2 gcd(矩阵乘法快速幂)
/* 矩阵乘法+快速幂. 一开始迷之题意.. 这个gcd有个规律. a b b c=a*x+b(x为常数). 然后要使b+c最小的话. 那x就等于1咯. 那么问题转化为求 a b b a+b 就是斐波 ...
- 【五一qbxt】day4 数论知识
这些东西大部分之前都学过了啊qwq zhx大概也知道我们之前跟着他学过这些了qwq,所以: 先讲新的东西qwq:(意思就是先讲我们没有学过的东西) 进制转换 10=23+21=1010(2) =32+ ...
- qbxt数学五一Day4
目录 1. 随机试验 2. 概率 1. 平凡 2. 条件概率 3. 期望 习题 1 2 3 4 1. 随机试验 定义: 不能预先确知结果 试验之前可以预测所有可能结果或范围 可以在相同条件下重复实验 ...
- python_way,day4 内置函数(callable,chr,随机验证码,ord),装饰器
python_way,day4 1.内置函数 - 下 制作一个随机验证码 2.装饰器 1.内置函数 - 下 callable() #对象能否被调用 chr() #10进制数字对应的ascii码表中的内 ...
- Spark菜鸟学习营Day4 单元测试程序的编写
Spark菜鸟学习营Day4 单元测试程序的编写 Spark相比于传统代码是比较难以调试的,单元测试的编写是非常必要的. Step0:需求分析 在测试案例编写前,需完成需求分析工作,明确程序所有的输入 ...
- Spark Tungsten揭秘 Day4 内存和CPU优化使用
Spark Tungsten揭秘 Day4 内存和CPU优化使用 今天聚焦于内存和CPU的优化使用,这是Spark2.0提供的关于执行时的非常大的优化部分. 对过去的代码研究,我们会发现,抽象的提高, ...
- Catalyst揭秘 Day4 analyzer解析
Catalyst揭秘 Day4 analyzer解析 今天继续解析catalyst,主要讲一下analyzer,在sql语句的处理流程中,analyzer是在sqlparse的基础上,把unresol ...
- Kakfa揭秘 Day4 Kafka中分区深度解析
Kakfa揭秘 Day4 Kafka中分区深度解析 今天主要谈Kafka中的分区数和consumer中的并行度.从使用Kafka的角度说,这些都是至关重要的. 分区原则 Partition代表一个to ...
随机推荐
- 突破Http协议
突破Http协议 我到不先说什么Http什么的,对于HTTP的彻底理解是http是应用层的一个程序,就像我们写的诸多客户端和服务器模型,我们可能为了可靠,为了方便数据的解析,我们在数据包中其实就是结构 ...
- php之mongodb插入数据后如何返回当前插入记录ID
<?php /** *插入记录 *参数: *$table_name:表名 *$record:记录 * *返回值: *成功:true *失败:false */ function insert($t ...
- 数据降维(Dimensionality reduction)
数据降维(Dimensionality reduction) 应用范围 无监督学习 图片压缩(需要的时候在还原回来) 数据压缩 数据可视化 数据压缩(Data Compression) 将高维的数据转 ...
- FZU 2221—— RunningMan——————【线性规划】
Problem 2221 RunningMan Accept: 17 Submit: 52Time Limit: 1000 mSec Memory Limit : 32768 KB P ...
- 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- ...
- [转].NET Core之Entity Framework Core 你如何创建 DbContext
本文转自:http://www.cnblogs.com/tdws/p/5874212.html 本文版权归博客园和作者吴双共同所有,欢迎转载,转载和爬虫请注明博客园蜗牛原文地址 http://www. ...
- 在 Linux 上创建第一个 Service Fabric Java 应用程序
先决条件 开始之前,请安装 Service Fabric SDK.Azure CLI,并在 Linux 开发环境中设置开发群集. 如果使用 Mac OS X,则可使用 Vagrant 在虚拟机中设置 ...
- 关于日常使用Azure MySQL中遇到的连接问题以及排查方法分享
由于防火墙问题,TCP keep alive 问题,以及 MySQL 自身的参数问题这三个在使用中比较常见,所以今天就分享下自己找到的排查方法. 今天先聊一聊防火墙问题 大多数人在第一次创建 MySQ ...
- PCA (主成分分析)详解——转载 古剑寒
转载地址:http://my.oschina.net/gujianhan/blog/225241 另外可以参考相关博文:http://blog.csdn.net/neal1991/article/de ...
- Redis的Publish/Subscribe
Publish/Subscribe 从字面上理解就是发布(Publish)与订阅(Subscribe),在Redis中,你可以设定对某一个key值进行消息发布及消息订阅,当一个key值上进行了消息发布 ...