看到现有的一篇 DSU on tree 的题解复杂度假了,于是我来再写一篇。

首先重新梳理思路,维护每棵子树内深度为某个值的节点是否存在。

维护这个东西可以直接 DSU on tree 也就是把小的子树内的信息加入大的子树。

然后加入点是判断是否能和已经存在的点构成长度为 \(K\) 的路径。

举个例子,对于经过点 \(rt\) 的从 \(x\) 到 \(y\) 的路径,长度是 \(dep_x - dep_{rt} + dep_y - dep_{rt}\)。

令上式值为 \(K\) 再移项就可以知道新加入的点需要满足如何的限制才可以做贡献。

最后注意一个点,我们不能暴力清空数组,正确做法是把这个桶用哈希维护,然后直接 \(O(1)\) 清空哈希表。

另外说一个特殊的地方:这份代码为了省事将加点和贡献放在了一起,如果计算方案数就会计重,如果想避免就需要对于每个子树中的所有节点先计算贡献再加入桶

最后上代码:

#include<bits/stdc++.h>
#include<bits/extc++.h>
using namespace std;
const int maxn = 1e4+114;
int depth[maxn],n,sz[maxn],big[maxn],L[maxn],R[maxn],Node[maxn],tot;
__gnu_pbds::gp_hash_table<int,int> cnt;
vector< pair<int,int> > edge[maxn];
int K;
bool flag;
inline void add(int u,int rt){
cnt[depth[u]]=1;
int v=K+depth[rt]*2-depth[u];
if(cnt[v]==1) flag=true;
}
inline void dfs1(int u,int fa,int w){
L[u]=++tot;
Node[tot]=u;
R[u]=L[u];
sz[u]=1;
depth[u]=depth[fa]+w;
for(pair<int,int> v:edge[u]){
if(v.first==fa) continue;
dfs1(v.first,u,v.second);
sz[u]+=sz[v.first];
if(sz[v.first]>sz[big[u]]){
big[u]=v.first;
}
R[u]=max(R[u],R[v.first]);
}
}
inline void dfs2(int u,int fa,bool keep){
for(pair<int,int> v:edge[u]){
if(v.first!=fa&&v.first!=big[u]) dfs2(v.first,u,false);
if(flag==true){
return ;
}
}
if(big[u]){
dfs2(big[u],u,true);
if(flag==true){
return ;
}
}
add(u,u);
for(pair<int,int> v:edge[u]){
if(v.first!=fa&&v.first!=big[u]){
for(int i=L[v.first];i<=R[v.first];i++){
add(Node[i],u);
if(flag==true){
return ;
}
}
}
}
if(keep==false){
cnt.clear();
}
}
int m;
int main(){
ios::sync_with_stdio(0);
cin.tie(0);
cout.tie(0);
cin>>n>>m;
for(int i=1;i<n;i++){
int u,v,w;
cin>>u>>v>>w;
edge[u].push_back(make_pair(v,w));
edge[v].push_back(make_pair(u,w));
}
dfs1(1,0,1);
while(m--){
cin>>K;
flag=false;
dfs2(1,0,true);
cnt.clear();
cout<<(flag==true?"AYE\n":"NAY\n");
}
}

P3806 题解的更多相关文章

  1. P3806 【模板】点分治1(题解)(点分治)

    P3806 [模板]点分治1(题解)(点分治) 洛谷题目传送门 #include<iostream> #include<cstdlib> #include<cstdio& ...

  2. 2016 华南师大ACM校赛 SCNUCPC 非官方题解

    我要举报本次校赛出题人的消极出题!!! 官方题解请戳:http://3.scnuacm2015.sinaapp.com/?p=89(其实就是一堆代码没有题解) A. 树链剖分数据结构板题 题目大意:我 ...

  3. noip2016十连测题解

    以下代码为了阅读方便,省去以下头文件: #include <iostream> #include <stdio.h> #include <math.h> #incl ...

  4. BZOJ-2561-最小生成树 题解(最小割)

    2561: 最小生成树(题解) Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1628  Solved: 786 传送门:http://www.lyd ...

  5. Codeforces Round #353 (Div. 2) ABCDE 题解 python

    Problems     # Name     A Infinite Sequence standard input/output 1 s, 256 MB    x3509 B Restoring P ...

  6. 哈尔滨理工大学ACM全国邀请赛(网络同步赛)题解

    题目链接 提交连接:http://acm-software.hrbust.edu.cn/problemset.php?page=5 1470-1482 只做出来四道比较水的题目,还需要加强中等题的训练 ...

  7. 2016ACM青岛区域赛题解

    A.Relic Discovery_hdu5982 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Jav ...

  8. poj1399 hoj1037 Direct Visibility 题解 (宽搜)

    http://poj.org/problem?id=1399 http://acm.hit.edu.cn/hoj/problem/view?id=1037 题意: 在一个最多200*200的minec ...

  9. 网络流n题 题解

    学会了网络流,就经常闲的没事儿刷网络流--于是乎来一发题解. 1. COGS2093 花园的守护之神 题意:给定一个带权无向图,问至少删除多少条边才能使得s-t最短路的长度变长. 用Dijkstra或 ...

  10. CF100965C题解..

    求方程 \[ \begin{array}\\ \sum_{i=1}^n x_i & \equiv & a_1 \pmod{p} \\ \sum_{i=1}^n x_i^2 & ...

随机推荐

  1. HouseParty原创故事全角色关系及主线剧情介绍(最新版)

    这是原创故事的主要的角色的主线及支线剧情的介绍及攻略和注意事项等. 这里的图比哔哩哔哩上的图清楚一点,哔哩哔哩同号:宅猫君007 以上是全角色的关系图 最新版本的游戏下载就在我的网站上:https:/ ...

  2. Python基础知识——缩进、标识符、保留字

    标识符 标识符就是程序中,使用的各种名称,例如:变量名.常量名.类名等等. 在 Python 中,对标识符格式的要求与 C/C++.Java 等差不多: 第一个字符必须是字母表中的字母或下划线 _ ; ...

  3. nmcli device status状态为unmanaged

    遇到报错:(device lo not available because device is strictly unmanaged) nmcli device status 查看设备状态 nmcli ...

  4. python 实现限流

    固定窗口 固定窗口就是记录一个固定的时间窗口内的操作次数,操作次数超过阈值则进行限流. def fix_window_limit(redis_obj, period, max_count): &quo ...

  5. Android OpenMAX(三)高通OMX组件实现基础

    上一节了解了OMX组件实现的基础内容,这一节我们以高通OMX实现为例,简单看看如何实现一个OMX组件.本节代码参考自: omx_core_cmp.cpp qc_omx_component.h omx_ ...

  6. PaddleOCR之高性能Go语言实现OCR识别

    最近为了让python语言能够直接调用PaddleOCR的C++的动态链接库,针对本人已经开源的PaddleOCR项目https://gitee.com/raoyutian/paddle-ocrsha ...

  7. MySQL学习笔记-数据定义语言

    SQL-数据定义语言(DDL) 一.操作数据库 1.查询 # 查询所有数据库 show databases; # 查询当前数据库 select database(); 2.创建 create data ...

  8. mescroll.js 使用

    mescroll.js 使用 附:点击查看中文文档 第一步:引入css和js // unpkg的CDN: <link rel="stylesheet" href=" ...

  9. codemirror-editor-vue3 输入框信息太多 输入框宽度溢出隐藏

    我们把div注释看下之前溢出的效果 因为有form表单在里面任何标签上面设置都是不行 因为有校验要显示校验的信息overflow是不起作用的 要是单独的codemirror-editor-vue3 编 ...

  10. kettle从入门到精通 第六十四课 ETL之kettle kettle中执行SQL脚本步骤,使用需当心

    1.群里有不定时会有同学反馈执行SQL脚本步骤使用有问题,那么咱们今天一起来学习下该步骤.trans中的执行SQL脚本有两方面功能,使用时需小心,不然很容易踩坑. 官方定义: 翻译: 您可以使用此步骤 ...