[luogu P3806] 【模板】点分治1

题目背景

感谢hzwer的点分治互测。

题目描述

给定一棵有n个点的树

询问树上距离为k的点对是否存在。

输入输出格式

输入格式:

n,m 接下来n-1条边a,b,c描述a到b有一条长度为c的路径

接下来m行每行询问一个K

输出格式:

对于每个K每行输出一个答案,存在输出“AYE”,否则输出”NAY”(不包含引号)

输入输出样例

输入样例#1: 复制

2 1
1 2 2
2
输出样例#1: 复制

AYE

说明

对于30%的数据n<=100

对于60%的数据n<=1000,m<=50

对于100%的数据n<=10000,m<=100,c<=1000,K<=10000000

首先这是点分裸题啊。。刷过点分的dalao都知道。

但似乎这题我只会calc里面n^2暴力扫?用不来m的100?

没事,让我们证明一下复杂度。。

T(n)=2T(n/2)+n^2。

然后我并不会主定理。。画了下二叉树图。

然后发现T(n)=2n^2(n^2+(1/2)n^2+(1/4)n^2+...)。

然后,因为n=10000,把常数写小一点,有点信仰就可以了。

code:

 #include <cstdio>
 #include <cstring>
 #include <algorithm>
 #define ms(a,x) memset(a,x,sizeof a)
 using namespace std;
 ,D=;
 ],son[N<<],w[N<<];
 int ro,subn,cnt,siz[N],mxs[N],dep[N],d[N];
 int m,c[D]; bool vis[N];
 void add (int x,int y,int z) {
     nxt[++tot]=lnk[x],lnk[x]=tot;
     son[tot]=y,w[tot]=z;
 }
 void dfs_size(int x,int p) {
     siz[x]=,mxs[x]=;
     for (int j=lnk[x]; j; j=nxt[j]) {
         if (son[j]==p||vis[son[j]]) continue;
         dfs_size(son[j],x);
         siz[x]+=siz[son[j]];
         if (mxs[x]<siz[son[j]]) mxs[x]=siz[son[j]];
     }
     if (mxs[x]<subn-mxs[x]) mxs[x]=subn-mxs[x];
     if (mxs[x]<mxs[ro]) ro=x;
 }
 void dfs_depth (int x,int p) {
     dep[++cnt]=d[x];
     for (int j=lnk[x]; j; j=nxt[j]) {
         if (son[j]==p||vis[son[j]]) continue;
         d[son[j]]=d[x]+w[j];
         dfs_depth(son[j],x);
     }
 }
 void calc (int x,int v) {
     cnt=,dfs_depth(x,);
     ; i<cnt; ++i) {
         ; j<=cnt; ++j) {
             c[dep[i]+dep[j]]+=v;
         }
     }
 }
 void node_divide (int x) {
     ro=,dfs_size(x,),vis[ro]=;
     d[ro]=,calc(ro,);
     for (int j=lnk[ro]; j; j=nxt[j]) {
         if (vis[son[j]]) continue;
         calc(son[j],-);
         subn=siz[son[j]];
         node_divide(son[j]);
     }
 }
 int main() {
     int x,y,z;
     scanf("%d%d",&n,&m);
     ; i<n; ++i) {
         scanf("%d%d%d",&x,&y,&z);
         add(x,y,z),add(y,x,z);
     }
     ro=,mxs[]=n,subn=n;
     node_divide();
     ; i<=m; ++i) {
         scanf("%d",&x);
         printf(?"AYE":"NAY");
     }
     ;
 }

[luogu P3806] 【模板】点分治1的更多相关文章

  1. [洛谷P3806] [模板] 点分治1

    洛谷 P3806 传送门 这个点分治都不用减掉子树里的了,直接搞就行了. 注意第63行 if(qu[k]>=buf[j]) 不能不写,也不能写成>. 因为这个WA了半天...... 如果m ...

  2. luoguP4721 【模板】分治 FFT

    P4721 [模板]分治 FFT 链接 luogu 题目描述 给定长度为 \(n-1\) 的数组 \(g[1],g[2],..,g[n-1]\),求 \(f[0],f[1],..,f[n-1]\),其 ...

  3. [luogu P3384] [模板]树链剖分

    [luogu P3384] [模板]树链剖分 题目描述 如题,已知一棵包含N个结点的树(连通且无环),每个节点上包含一个数值,需要支持以下操作: 操作1: 格式: 1 x y z 表示将树从x到y结点 ...

  4. 洛谷 P4721 【模板】分治 FFT 解题报告

    P4721 [模板]分治 FFT 题目背景 也可用多项式求逆解决. 题目描述 给定长度为 \(n−1\) 的数组 \(g[1],g[2],\dots,g[n-1]\),求 \(f[0],f[1],\d ...

  5. Luogu P2742 模板-二维凸包

    Luogu P2742 模板-二维凸包 之前写的实在是太蠢了.于是重新写了一个. 用 \(Graham\) 算法求凸包. 注意两个向量 \(a\times b>0\) 的意义是 \(b\) 在 ...

  6. LG4721 【模板】分治 FFT

    P4721 [模板]分治 FFT 题目背景 也可用多项式求逆解决. 题目描述 给定长度为 $n-1$ 的数组 $g[1],g[2],..,g[n-1]$,求 $f[0],f[1],..,f[n-1]$ ...

  7. luogu P3919 [模板]可持久化数组(可持久化线段树/平衡树)(主席树)

    luogu P3919 [模板]可持久化数组(可持久化线段树/平衡树) 题目 #include<iostream> #include<cstdlib> #include< ...

  8. 模板·点分治(luogu P3806)

    [模板]洛谷·点分治 1.求树的重心 树的重心:若A点的子树中最大的子树的size[] 最小时,A为该树的中心 步骤: 所需变量:siz[x] 表示 x 的子树大小(含自己),msz[x] 表示 其子 ...

  9. Luogu P3806 点分治模板1

    题意: 给定一棵有n个点的树询问树上距离为k的点对是否存在. 分析: 这个题的询问和点数都不多(但是显然暴力是不太好过的,即使有人暴力过了) 这题应该怎么用点分治呢.显然,一个模板题,我们直接用套路, ...

随机推荐

  1. subversion实用命令整理

    使用命令在仓库中创建目录 使用命令查看仓库中的内容 使用命令删除仓库中的内容 创建目录 svn mkdir --parents -m 'makeSubDirectory' file:///path/t ...

  2. HTTP劫持和DNS劫持

    HTTP劫持和DNS劫持 首先对运营商的劫持行为做一些分析,他们的目的无非就是赚钱,而赚钱的方式有两种: 1.对正常网站加入额外的广告,这包括网页内浮层或弹出广告窗口: 2.针对一些广告联盟或带推广链 ...

  3. c# 调用RDP和SSH实现远程登陆

    1.ssh的登陆实现: windows平台可以安装OpenSSHforWindows 后,可以通过cmd 执行ssh的指令. 也可以在c#编程中实现ssh的登陆: var p = new System ...

  4. 用AtomicStampedReference解决ABA问题

    在运用CAS做Lock-Free操作中有一个经典的ABA问题: 线程1准备用CAS将变量的值由A替换为B,在此之前,线程2将变量的值由A替换为C,又由C替换为A,然后线程1执行CAS时发现变量的值仍然 ...

  5. replace用法替换实例

    实例一: 待处理字符串:str="display=test name=mu display=temp" 要求:把display=后的值都改成localhost JS处理方法: st ...

  6. Mapped Statements collection already contains value for ***.***的问题

    情景,在我们配置项目或者开发的过程中,可能由于项目工程量大或误操作等原因,造成Map映射文件的ID重复,造成项目启动报以下错误, org.springframework.beans.factory.B ...

  7. Haystack全文检索

    1.什么是Haystack Haystack是django的开源全文搜索框架(全文检索不同于特定字段的模糊查询,使用全文检索的效率更高 ),该框架支持Solr,Elasticsearch(java写的 ...

  8. mybatis之Mybatis_demo

    这篇博文通过简单的CRUD案例,让大家能够快速的上手,使用mybatis.   1,在eclipse中新建java project项目 mybatis_demo 2,在mybatis_demo项目中建 ...

  9. Redis 错误:Failed with result 'start-limit-hit'

    Redis 错误:Failed with result 'start-limit-hit' 背景 Redis 版本为 5.0.4: 文件 /etc/systemd/system/redis.servi ...

  10. os.remove异常处理

    这种情况,正反斜杠都没问题.(windows环境下) 这种情况会出现下列异常 对于目录的形式,把反斜杠改成正斜杠就好了