【佛山市选2013】JZOJ2020年8月7日提高组T2 树环转换
【佛山市选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 树环转换的更多相关文章
- 【五校联考1day2】JZOJ2020年8月12日提高组T2 我想大声告诉你
		[五校联考1day2]JZOJ2020年8月12日提高组T2 我想大声告诉你 题目 Description 因为小Y 是知名的白富美,所以自然也有很多的追求者,这一天这些追求者打算进行一次游戏来踢出一 ... 
- JZOJ2020年8月11日提高组T2 宝石
		JZOJ2020年8月11日提高组T2 宝石 题目 Description 见上帝动了恻隐之心,天后也想显示一下慈悲之怀,随即从口袋中取出一块魔术方巾,让身边的美神维纳斯拿到后堂的屏风上去试试,屏风是 ... 
- 【GDKOI2014】JZOJ2020年8月13日提高组T2 石油储备计划
		[GDKOI2014]JZOJ2020年8月13日提高组T2 石油储备计划 题目 Description Input Output 对于每组数据,输出一个整数,表示达到"平衡"状态 ... 
- 【NOIP2015模拟11.4】JZOJ2020年8月6日提高组T2 最优交换
		[NOIP2015模拟11.4]JZOJ2020年8月6日提高组T2 最优交换 题目 题解 题意 有一个长度为\(n\)的正整数 最多可以进行\(k\)次操作 每次操作交换相邻两个位置上的数 问可以得 ... 
- 【佛山市选2013】JZOJ2020年8月7日提高组T3 海明距离
		[佛山市选2013]JZOJ2020年8月7日提高组T3 海明距离 题目 描述 对于二进制串a,b,他们之间的海明距离是指两个串异或之后串中1的个数.异或的规则为: 0 XOR 0 = 0 1 XOR ... 
- 【佛山市选2013】JZOJ2020年8月7日提高组T1 回文子序列
		[佛山市选2013]JZOJ2020年8月7日提高组T1 回文子序列 题目 描述 回文序列是指左右对称的序列.例如1 2 3 2 1是回文序列,但是1 2 3 2 2就不是.我们会给定一个N×M的矩阵 ... 
- 【GDOI2007】JZOJ2020年8月10日提高组T1 夏娜的菠萝包
		[GDOI2007]JZOJ2020年8月10日提高组T1 夏娜的菠萝包 题目 Description 夏娜很喜欢吃菠萝包,她的经纪人RC每半个月就要为她安排接下来的菠萝包计划.今天是7月份,RC又要 ... 
- JZOJ2020年8月11日提高组T4 景点中心
		JZOJ2020年8月11日提高组T4 景点中心 题目 Description 话说宁波市的中小学生在镇海中学参加计算机程序设计比赛,比赛之余,他们在镇海中学的各个景点参观.镇海中学共有n个景点,每个 ... 
- JZOJ2020年8月11日提高组T3 页
		JZOJ2020年8月11日提高组T3 页 题目 Description 战神阿瑞斯听说2008年在中华大地上,将举行一届规模盛大的奥林匹克运动会,心中顿觉异常兴奋,他想让天马在广阔的天空上,举行一场 ... 
随机推荐
- [Luogu P3469] [POI2008]BLO-Blockade (割点)
			题面 传送门:https://www.luogu.org/problemnew/show/P3469 Solution 先跟我大声念: poi! 然后开始干正事. 首先,我们先把题目中的点分为两类:去 ... 
- 初步配置基于Struts的maven的Web项目demo
			1.创建mavenweb项目 eclipse | Idea 中创建maven项目,具体步骤PASS. 2.导入Struts2核心架包 Idea中在maven项目上,选择ADD FRAMEWORK ec ... 
- 转:Microsoft Dynamics AX内部版本号概述
			Overview of Microsoft Dynamics AX build numbers 转自:https://community.dynamics.com/ax/b/axsupport/arc ... 
- LeetCode 热题 HOT 100(05,正则表达式匹配)
			LeetCode 热题 HOT 100(05,正则表达式匹配) 不够优秀,发量尚多,千锤百炼,方可成佛. 算法的重要性不言而喻,无论你是研究者,还是最近比较火热的IT 打工人,都理应需要一定的算法能力 ... 
- 鸿蒙开发板外设控制 之 实现物理按键的“长按事件”(按键通用框架 V0.0.2)
			我在之前的帖子<实现按键"按下事件"和"释放事件"的通用框架(V0.0.1)>中阐述了DTButton-V0.0.1的设计思路,并且也在帖子中开源了 ... 
- 弹性盒模型flex-grow的计算
			flex-grow属性是弹性盒布局模块的子属性. 它定义了弹性项目在必要时增长的能力. 它接受作为比例的无单位值. 它决定了项目应在伸缩容器内部占用多少可用空间. 例如,如果所有项目的flex-gro ... 
- vpp dpdk 安装使用笔记
			编译安装: make install-dep make build 编译 vpp 查看 pci 网卡 id : lshw -class network -businfo DPDK hugepage ... 
- linux 内存泄露 valgrind
			内泄漏工具 valgrind: https://linux.die.net/man/1/valgrind www.valgrind.org/docs/manual/index.html www.val ... 
- 二:Tomcat与登录
			在使用Tomcat部署服务器之前我们需要写一个页面登录的HTML文本 该文本如下 <!DOCTYPE html> <html> <head> <meta ch ... 
- Redis在springboot项目的使用
			一.在pom.xml配置redis依赖 <!-- redis客户端代码 --> <dependency> <groupId>org.springframework. ... 
