题目链接

AtCoder:https://agc008.contest.atcoder.jp/tasks/agc008_f

洛谷:https://www.luogu.org/problemnew/show/AT2268

Solution

首先假设所有点都是黑的。

设\(f(i,d)\)表示\(i\)节点扩展\(k\)步的点集,那么答案就是本质不同的点集个数。

我们考虑一个很巧妙的计数方法:每种点集都在\(d\)最小时被算一次,那么二元组一定要满足这样的性质:

  • 首先我们硬点全集不选,答案最后加一。
  • 对于\((x,d)\),我们要求所有于\(x\)相邻的点\(y\)都不存在\(f(x,d)=f(y,d-1)\)。

那么我们可以发现每个点都有一个选取上界,这个\(d\)满足以下性质:

  • \(d\in [0,dis_x-1]\),其中\(dis_x\)表示离\(x\)最远点的距离。
  • \(d\in [0,dis2_v+1]\),其中\(v\)为\(x\)的儿子,\(dis2_v\)表示\(x\)不经过\(v\)的\(dis\)最大值。

这个画个图就可以知道。

那么如果有一些点不是黑的,我们考虑给这些点定个下界,下界就是以\(x\)为根\(x\)的儿子的子树中含有黑点的子树的\(dis_1\)的最小值,这样就可以保证这种方案可以被一个黑点产生。

然后\(\rm tree\ dp\)实现就好了,复杂度\(O(n)\)。

#include<bits/stdc++.h>
using namespace std; void read(int &x) {
x=0;int f=1;char ch=getchar();
for(;!isdigit(ch);ch=getchar()) if(ch=='-') f=-f;
for(;isdigit(ch);ch=getchar()) x=x*10+ch-'0';x*=f;
} void print(int x) {
if(x<0) putchar('-'),x=-x;
if(!x) return ;print(x/10),putchar(x%10+48);
}
void write(int x) {if(!x) putchar('0');else print(x);putchar('\n');} #define lf double
#define ll long long #define pii pair<int,int >
#define vec vector<int > #define pb push_back
#define mp make_pair
#define fr first
#define sc second const int maxn = 5e5+10;
const int inf = 1e9;
const lf eps = 1e-8; char s[maxn];
int sz[maxn],d1[maxn],d2[maxn],d3[maxn],d4[maxn],n,head[maxn],tot,f[maxn];
struct edge{int to,nxt;}e[maxn<<1]; void add(int u,int v) {e[++tot]=(edge){v,head[u]},head[u]=tot;}
void ins(int u,int v) {add(u,v),add(v,u);} void dfs(int x,int fa) {
sz[x]=s[x]-'0',f[x]=fa;d3[x]=1e9;
for(int v,i=head[x];i;i=e[i].nxt)
if((v=e[i].to)!=fa) {
dfs(v,x),sz[x]+=sz[v];
d1[x]=max(d1[x],d1[v]+1);
if(sz[v]) d3[x]=min(d3[x],d1[e[i].to]+1);
}
} void dfs2(int x,int fa) {
int fr=0,sc=0;if(fa) d4[x]=d2[x]-1;
for(int v,i=head[x];i;i=e[i].nxt) {
if((v=e[i].to)==fa) continue;
if(d1[v]+1>=fr) sc=fr,fr=d1[v]+1;
else if(d1[v]+1>sc) sc=d1[v]+1;
}
for(int v,i=head[x];i;i=e[i].nxt) {
if((v=e[i].to)==fa) continue;
if(d1[v]+1==fr) d2[v]=max(d2[x],sc)+1;
else d2[v]=max(d2[x],fr)+1;
dfs2(e[i].to,x);
}
} int main() {
read(n);for(int i=1,x,y;i<n;i++) read(x),read(y),ins(x,y);
scanf("%s",s+1);dfs(1,0),dfs2(1,0);
ll ans=0;int mx,mn;
for(int x=1;x<=n;x++) {
mx=max(d1[x],d2[x])-1;
if(s[x]=='0') mn=min(d3[x],sz[1]==sz[x]?(int)1e9:d2[x]);else mn=0;
for(int i=head[x];i;i=e[i].nxt)
if(e[i].to==f[x]) mx=min(mx,d1[x]+1);
else mx=min(mx,d4[e[i].to]+1);
if(mx>=mn) ans+=(ll)mx-mn+1;
}printf("%lld\n",ans+1ll);
return 0;
}

[AT2268] [agc008_f] Black Radius的更多相关文章

  1. BAS/BRAS/RADIUS简介

    标签: java radius协议   linux radius认证服务器   转自: http://blog.csdn.net/sun93732/article/details/5999274 由R ...

  2. Creating a radius based VPN with support for Windows clients

    This article discusses setting up up an integrated IPSec/L2TP VPN using Radius and integrating it wi ...

  3. Java处理Radius access-challenge

    最近使用 RSA Authentication Manager, 并且与其自带的Radius server整合, RSA的Radius server 配置不太透明, 目前只配成功了PAP方式的验证,C ...

  4. (1)编写一个接口ShapePara,要求: 接口中的方法: int getArea():获得图形的面积。int getCircumference():获得图形的周长 (2)编写一个圆类Circle,要求:圆类Circle实现接口ShapePara。 该类包含有成员变量: radius:public 修饰的double类型radius,表示圆的半径。 x:private修饰的double型变量x,

    package com.hanqi.test; //创建接口 public interface ShapePara { //获取面积的方法 double getArea(); //获取周长的方法 do ...

  5. radius服务器搭建

    yum install -y unzip gcc-c++ cd /opt unzip release-stable.zip mv ToughRADIUS-release-stable toughrad ...

  6. Radius 远程用户拨号认证系统

    RADIUS 锁定 本词条由“科普中国”百科科学词条编写与应用工作项目 审核 . RADIUS:Remote Authentication Dial In User Service,远程用户拨号认证系 ...

  7. 【转】 浅谈Radius协议

    浅谈Radius协议 2013-12-03 16:06 5791人阅读 评论(0) 收藏 举报  分类: Radius协议分析(6)  从事Radius协议开发有段时间了,小弟不怕才疏学浅,卖弄一下, ...

  8. 转:浅谈Radius协议 -来自CSDN:http://blog.csdn.net/wangpengqi/article/details/17097221

    浅谈Radius协议 2013-12-03 16:06 5791人阅读 评论(0) 收藏 举报  分类: Radius协议分析(6)  从事Radius协议开发有段时间了,小弟不怕才疏学浅,卖弄一下, ...

  9. Radius session

    1,EAP 中继 client start, NAS require identity, client sent username, NAS sent username to sever, serve ...

随机推荐

  1. halcon 手眼标定的坐标转换原理讲解

    原文链接:https://blog.csdn.net/opencv_learner/article/details/82113323 一直以来,对于手眼标定所涉及到的坐标系及坐标系之间的转换关系都没能 ...

  2. Jmeter关联处理

    采桑子·重阳 人生易老天难老, 岁岁重阳. 今又重阳, 战地黄花分外香. 一年一度秋风劲, 不似春光. 胜似春光, 廖廓江天万里霜. 当请求之间有依赖关系,比如一个请求的入参是另一个请求返回的数据,这 ...

  3. python-gevent模块实现socket大并发

    服务器端:gevent_server.py 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 ...

  4. 基于tensorflow实现mnist手写识别 (多层神经网络)

    标题党其实也不多,一个输入层,三个隐藏层,一个输出层 老样子先上代码 导入mnist的路径很长,现在还记不住 import tensorflow as tf import tensorflow.exa ...

  5. 解决 vuex mapGetters 语法报错 (Unexpected token )

    在使用vuex2的mapGetters 和 mapActions 的方法时,借助 stage2 的 Object Rest Operator 特性,可以写出下面代码:  computed: { ... ...

  6. Final阶段中间产物

    空天猎功能说明书:https://git.coding.net/liusx0303/Plane.git 空天猎代码控制:https://coding.net/u/MR__Chen/p/SkyHunte ...

  7. 第38次Scrum会议(12/4)【欢迎来怼】

    一.小组信息 队名:欢迎来怼 小组成员 队长:田继平 成员:李圆圆,葛美义,王伟东,姜珊,邵朔,阚博文 小组照片 二.开会信息 时间:2017/12/4 17:50~18:20,总计30min. 地点 ...

  8. 如何:通过将HTML编码应用于字符串来防止Web应用程序中的脚本漏洞

    当用户可以将可执行代码(或脚本)添加到您的应用程序中时,会发生大多数脚本攻击.默认情况下,ASP.NET提供请求验证,如果表单发布包含任何HTML,则会引发错误. 您可以通过以下方式帮助防止脚本漏洞利 ...

  9. react 组件构建设计

    项目设计中,可以从顶层React元素开始,然后实现它的子组件,自顶向下来构建组件的层级组件的写法:1.引入依赖模块2.定义React组件3.作为模块导出React组件4.子组件更新父组件的机制5.父组 ...

  10. jsp与Ajax技术

    Ajax 是Asynchronous Javascript and XML的缩写,异步的JavaScript和xml.Ajax是由JavaScript.XML.CSS.DOM等多种已有技术的结合,它可 ...