【佛山市选2013】JZOJ2020年8月7日提高组T2 树环转换

题目

描述

给定一棵N个节点的树,去掉这棵树的一条边需要消耗值1,为这个图的两个点加上一条边也需要消耗值1。树的节点编号从1开始。在这个问题中,你需要使用最小的消耗值(加边和删边操作)将这棵树转化为环,不允许有重边。

环的定义如下:

  • 该图有N个点,N条边。
  • 每个顶点的度数为2。
  • 任意两点是可达的。

树的定义如下:

  • 该图有N个点,N-1条边。
  • 任意两点是可达的。

数据

对于20%的数据,有1≤N≤10。

对于100%的数据,有1≤N≤1000000。

题解

题意

给出一棵树

每次删边加边的代价都为一

问最小代价将树转成环

分析

看到树呢,很容易 (个屁) 想到树形DP

但是如果直接设状态的话不好转移

思考:环是什么

不就是一条链再加上一条边吗

一条链是什么

特殊的树呀!

那么就可以设\(f[i]\)表示以\(i\)为根的子树转成链的最小代价

如果想去推方程的话,先别急

我们来看一下什么是链



一张丑陋的图

很容易发现

除了第一个和最后一个点

其他节点的度数都为2

那么是不是可以设\(f[i][0]\)表示根节点\(i\)转换成链之后是两个端点中的一个的最小代价,\(f[i][1]\)表示不管\(i\)的位置的最小代价

放方程:

告知:\(S\)表示\(\sum_\ f[son][1]\),\(c\)表示儿子的个数,\(u,v\)是\(i\)的儿子

\(f[i][0]=min\begin{cases}S+2c\\S-(f[u][1]-f[u][0])+2*(c-1)\end{cases}\)

\(f[i][1]=min\begin{cases}f[i][0]\\S-(f[u][1]-f[u][0]+2*(c-2)\end{cases}\)

小小的优化:

对于\(u,v\)的话,既然要使更小,那么\(f[u][1]-f[u][0]\)之类的就要最大

记一下最大和次大就可以了

至于解释的话





另外就是

本题卡系统栈!!!

所以你可以打\(BFS\)或者开人工栈

Code

#include<cstdio>
#include<iostream>
#define inf 99999999
using namespace std;
struct node
{
int to,next,head;
}a[2000005];
int n,i,x,y,tot,f[1000005][3],d[1000005],father[1000005];
bool b[1000005];
void add(int x,int y)
{
tot++;
a[tot].to=y;
a[tot].next=a[x].head;
a[x].head=tot;
}
void bfs(int now)
{
int i,j,h,t,x,mx1,mx2,s,num;
h=0;
t=1;
d[1]=now;
b[now]=true;
while (h<t)
{
h++;
for (i=a[d[h]].head;i;i=a[i].next)
{
x=a[i].to;
if (b[x]==false)
{
t++;
d[t]=x;
b[x]=true;
}
else father[d[h]]=x;
}
}
for (j=t;j;j--)
{
mx1=mx2=-inf;
num=s=0;
for (i=a[d[j]].head;i;i=a[i].next)
{
x=a[i].to;
if (x!=father[d[j]])
{
num++;
s+=f[x][1];
if (f[x][1]-f[x][0]>mx1)
{
mx2=mx1;
mx1=f[x][1]-f[x][0];
}
else
{
if (f[x][1]-f[x][0]>mx2) mx2=f[x][1]-f[x][0];
}
}
}
f[d[j]][0]=min(s+2*num,s-mx1+2*(num-1));
f[d[j]][1]=min(f[d[j]][0],s-mx1-mx2+2*(num-2));
}
}
int main()
{
freopen("T2.in","r",stdin);
freopen("T2.out","w",stdout);
scanf("%d",&n);
for (i=1;i<n;i++)
{
scanf("%d%d",&x,&y);
add(x,y);
add(y,x);
}
bfs(1);
printf("%d\n",min(f[1][0],f[1][1])+1);
fclose(stdin);
fclose(stdout);
return 0;
}

【佛山市选2013】JZOJ2020年8月7日提高组T2 树环转换的更多相关文章

  1. 【五校联考1day2】JZOJ2020年8月12日提高组T2 我想大声告诉你

    [五校联考1day2]JZOJ2020年8月12日提高组T2 我想大声告诉你 题目 Description 因为小Y 是知名的白富美,所以自然也有很多的追求者,这一天这些追求者打算进行一次游戏来踢出一 ...

  2. JZOJ2020年8月11日提高组T2 宝石

    JZOJ2020年8月11日提高组T2 宝石 题目 Description 见上帝动了恻隐之心,天后也想显示一下慈悲之怀,随即从口袋中取出一块魔术方巾,让身边的美神维纳斯拿到后堂的屏风上去试试,屏风是 ...

  3. 【GDKOI2014】JZOJ2020年8月13日提高组T2 石油储备计划

    [GDKOI2014]JZOJ2020年8月13日提高组T2 石油储备计划 题目 Description Input Output 对于每组数据,输出一个整数,表示达到"平衡"状态 ...

  4. 【NOIP2015模拟11.4】JZOJ2020年8月6日提高组T2 最优交换

    [NOIP2015模拟11.4]JZOJ2020年8月6日提高组T2 最优交换 题目 题解 题意 有一个长度为\(n\)的正整数 最多可以进行\(k\)次操作 每次操作交换相邻两个位置上的数 问可以得 ...

  5. 【佛山市选2013】JZOJ2020年8月7日提高组T3 海明距离

    [佛山市选2013]JZOJ2020年8月7日提高组T3 海明距离 题目 描述 对于二进制串a,b,他们之间的海明距离是指两个串异或之后串中1的个数.异或的规则为: 0 XOR 0 = 0 1 XOR ...

  6. 【佛山市选2013】JZOJ2020年8月7日提高组T1 回文子序列

    [佛山市选2013]JZOJ2020年8月7日提高组T1 回文子序列 题目 描述 回文序列是指左右对称的序列.例如1 2 3 2 1是回文序列,但是1 2 3 2 2就不是.我们会给定一个N×M的矩阵 ...

  7. 【GDOI2007】JZOJ2020年8月10日提高组T1 夏娜的菠萝包

    [GDOI2007]JZOJ2020年8月10日提高组T1 夏娜的菠萝包 题目 Description 夏娜很喜欢吃菠萝包,她的经纪人RC每半个月就要为她安排接下来的菠萝包计划.今天是7月份,RC又要 ...

  8. JZOJ2020年8月11日提高组T4 景点中心

    JZOJ2020年8月11日提高组T4 景点中心 题目 Description 话说宁波市的中小学生在镇海中学参加计算机程序设计比赛,比赛之余,他们在镇海中学的各个景点参观.镇海中学共有n个景点,每个 ...

  9. JZOJ2020年8月11日提高组T3 页

    JZOJ2020年8月11日提高组T3 页 题目 Description 战神阿瑞斯听说2008年在中华大地上,将举行一届规模盛大的奥林匹克运动会,心中顿觉异常兴奋,他想让天马在广阔的天空上,举行一场 ...

随机推荐

  1. Ordering Cows

    题意描述 好像找不到链接(找到了请联系作者谢谢),所以题目描述会十分详细: Problem 1: Ordering Cows [Bruce Merry, South African Computer ...

  2. Codeforce算法题 | 你能想出解法,让你的基友少氪金吗?

    在TechFlow学长的公众号里发现一道挺有意思的CF算法题,现在利用学长的思路学习一下 题目链接:https://codeforces.com/contest/1418/problem/C 题意 这 ...

  3. Python调用飞书发送消息

    一.创建飞书机器人 自定义飞书机器人操作步骤,具体详见飞书官方文档:<机器人 | 如何在群聊中使用机器人?>

  4. 释放至强平台 AI 加速潜能 汇医慧影打造全周期 AI 医学影像解决方案

    基于英特尔架构实现软硬协同加速,显著提升新冠肺炎.乳腺癌等疾病的检测和筛查效率,并帮助医疗科研平台预防"维度灾难"问题 <PAGE 1 LEFT COLUMN: CUSTOM ...

  5. ashx接收前台传来的数据

    前台js: $(function () { $.ajax({ url: "/TestAshx/GetJson.ashx", type: "post", data ...

  6. 类似阿里双十一的可视化看板是怎么做的?无人机三维GIS看板也来了!

    天猫双十一数据可视化看板 每年的双十一,天猫都会在整点时刻直播战绩,惊叹于可怕战绩的同时,也会被背后展示的数据大屏吸引,这样让人眼前一亮的可视化数据看板是怎么做出来的? 所谓可视化数据看板,就是挂在墙 ...

  7. 重写ceph-lazy

    前言 这个工具最开始是从sebastien的blog里面看到的,这个是 Gregory Charot(工具的作者)写的,通常我们在获取一个ceph的信息的时候,需要敲一连串的命令去获得自己需要的信息, ...

  8. xpth定位元素

  9. hashlib模块(摘要算法)

    hashlib(1) # hashlib模块 # 现在写登录认证的时候,需要保存用户名和密码,用户名和密码是保存在文件中,并且都是明文,一旦丢了就完蛋了.所以 # 可以用hashlib将密码转换成密文 ...

  10. vue实现增删改查(内附源代码)

    VUE+Element实现增删改查 @ 目录 VUE+Element实现增删改查 前言 实验步骤 总结: 源代码 前言 &最近因为一些原因,没有更博客,昨天老师布置了一个作业,用vue实现增删 ...