bzoj1907: 树的路径覆盖(树形DP)
2024-10-16 18:45:11
一眼题...
f[i][0]表示在i连接一个子树的最小值,f[i][1]表示在i连接两个子树的最小值,随便转移...
样例挺强的1A了美滋滋...
UPD:学习了2314的写法之后短了好多T T
#include<iostream>
#include<cstring>
#include<cstdlib>
#include<cstdio>
#include<algorithm>
using namespace std;
const int maxn=, inf=1e9;
struct poi{int too, pre;}e[maxn];
int n, T, tot, x, y;
int f[maxn][], last[maxn];
void read(int &k)
{
int f=; k=; char c=getchar();
while(c<'' || c>'') c=='-' && (f=-), c=getchar();
while(c<='' && c>='') k=k*+c-'', c=getchar();
k*=f;
}
inline void add(int x, int y){e[++tot]=(poi){y, last[x]}; last[x]=tot;}
inline int min(int a, int b){return a<b?a:b;}
void dfs(int x, int fa)
{
f[x][]=maxn; f[x][]=; int sum=;
for(int i=last[x], too;i;i=e[i].pre)
if((too=e[i].too)!=fa)
{
dfs(too, x);
f[x][]=min(f[x][]+min(f[too][], f[too][]), f[x][]+f[too][]-);
f[x][]=min(f[x][]+min(f[too][], f[too][]), sum+f[too][]);
sum+=min(f[too][], f[too][]);
}
}
int main()
{
read(T);
while(T--)
{
read(n); memset(last, , (n+)<<); tot=;
for(int i=;i<n;i++) read(x), read(y), add(x, y), add(y, x);
dfs(, ); printf("%d\n", min(f[][], f[][]));
}
}
旧代码:
#include<iostream>
#include<cstring>
#include<cstdlib>
#include<cstdio>
#include<algorithm>
using namespace std;
const int maxn=, inf=1e9;
struct poi{int too, pre;}e[maxn];
int n, T, tot, x, y;
int f[maxn][], last[maxn];
void read(int &k)
{
int f=; k=; char c=getchar();
while(c<'' || c>'') c=='-' && (f=-), c=getchar();
while(c<='' && c>='') k=k*+c-'', c=getchar();
k*=f;
}
inline void add(int x, int y){e[++tot]=(poi){y, last[x]}; last[x]=tot;}
inline int min(int a, int b){return a<b?a:b;}
void dfs(int x, int fa)
{
int mn1=inf, mn2=inf, mni1=, mni2=, tmp=; f[x][]=; f[x][]=-;
for(int i=last[x], too;i;i=e[i].pre)
if((too=e[i].too)!=fa)
{
dfs(too, x);
f[x][]+=min(f[too][], f[too][]);
if(f[too][]==min(f[too][], f[too][])) tmp=;
if(f[too][]-min(f[too][], f[too][])<mn1) mn1=f[too][]-min(f[too][], f[too][]), mni1=too;
else if(f[too][]-min(f[too][], f[too][])<mn2) mn2=f[too][]-min(f[too][], f[too][]), mni2=too;
}
f[x][]+=tmp;
if(!(f[x][]-tmp)) {f[x][]=; f[x][]=inf; return;}
if(mn2==inf) {f[x][]=inf; return;}
for(int i=last[x], too;i;i=e[i].pre)
if((too=e[i].too)!=fa)
{
if(too==mni1 || too==mni2) f[x][]+=f[too][];
else f[x][]+=min(f[too][], f[too][]);
}
}
int main()
{
read(T);
while(T--)
{
read(n); memset(last, , (n+)<<); tot=;
for(int i=;i<n;i++) read(x), read(y), add(x, y), add(y, x);
dfs(, ); printf("%d\n", min(f[][], f[][]));
}
}
最新文章
- ASP.NET MVC5+EF6+EasyUI 后台管理系统(49)-工作流设计-我的申请
- 和Java相关的书籍,想成为架构师的请收藏一下啊
- Windows Server2008 下用于.NET Framework3.0版本的问题无法在IIS7中配置.NET Framework4.0节点的问题
- myeclipse中导入js报如下错误Syntax error on token ";Invalid Regular Expression Options";, no accurate correc
- [工作中的设计模式]迭代子模式Iterator
- 提高你css技能的css开发技巧(转载)
- 0012 win7x64安装CentOS7
- php 安装redis扩展
- 【Android - 进阶】之图片压缩
- C++高精度运算类bign (重载操作符)
- NEC红外遥控协议理解与实现
- Win7 Cygwin环境试验Nutch tutorial遇到的异常解决方法
- 微信企业号接收消息(使用SpringMVC)
- 笔记:XML-解析文档-DOM
- Web Uploader初始化隐藏容器失败及点击上传图片时反应较慢的问题
- 【C/C++】Rotate Array
- 第二章 flex输入输出结构
- gridview列超链接的几种设置方法
- 详解PhpSpreadsheet设置单元格
- 《转》python学习(6)序列类型-字符串
热门文章
- 优化 VR 动作类游戏《Space Pirate Trainer*》以便在英特尔&#174; 集成显卡上实现卓越的表现
- python购物车优化
- 01_基于TCP的循环为同一个客户端下载文件的下载器
- Switch Game :因子数
- 《Cocos2d-x游戏开发实战精解》学习笔记4--实战一个简单的钢琴
- Action Required: Please provide your Tax Identity Information - Amazon Seller Tax Identity Collection
- Android:有关下拉菜单导航的学习(供自己参考)
- Redis 列表(List)
- 团队作业4——第一次项目冲刺(Alpha版本)第一次
- Varnish是一款高性能的开源HTTP加速器