一眼题...

  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[][]));
}
}

最新文章

  1. ASP.NET MVC5+EF6+EasyUI 后台管理系统(49)-工作流设计-我的申请
  2. 和Java相关的书籍,想成为架构师的请收藏一下啊
  3. Windows Server2008 下用于.NET Framework3.0版本的问题无法在IIS7中配置.NET Framework4.0节点的问题
  4. myeclipse中导入js报如下错误Syntax error on token &quot;Invalid Regular Expression Options&quot;, no accurate correc
  5. [工作中的设计模式]迭代子模式Iterator
  6. 提高你css技能的css开发技巧(转载)
  7. 0012 win7x64安装CentOS7
  8. php 安装redis扩展
  9. 【Android - 进阶】之图片压缩
  10. C++高精度运算类bign (重载操作符)
  11. NEC红外遥控协议理解与实现
  12. Win7 Cygwin环境试验Nutch tutorial遇到的异常解决方法
  13. 微信企业号接收消息(使用SpringMVC)
  14. 笔记:XML-解析文档-DOM
  15. Web Uploader初始化隐藏容器失败及点击上传图片时反应较慢的问题
  16. 【C/C++】Rotate Array
  17. 第二章 flex输入输出结构
  18. gridview列超链接的几种设置方法
  19. 详解PhpSpreadsheet设置单元格
  20. 《转》python学习(6)序列类型-字符串

热门文章

  1. 优化 VR 动作类游戏《Space Pirate Trainer*》以便在英特尔&#174; 集成显卡上实现卓越的表现
  2. python购物车优化
  3. 01_基于TCP的循环为同一个客户端下载文件的下载器
  4. Switch Game :因子数
  5. 《Cocos2d-x游戏开发实战精解》学习笔记4--实战一个简单的钢琴
  6. Action Required: Please provide your Tax Identity Information - Amazon Seller Tax Identity Collection
  7. Android:有关下拉菜单导航的学习(供自己参考)
  8. Redis 列表(List)
  9. 团队作业4——第一次项目冲刺(Alpha版本)第一次
  10. Varnish是一款高性能的开源HTTP加速器