[BZOJ2051]A Problem For Fun/[BZOJ2117]Crash的旅游计划/[BZOJ4317]Atm的树

题目大意:

给出一个\(n(n\le10^5)\)个结点的树,每条边有一个正整数权值\(w_i(w_i\le10^4)\),定义两个结点的距离为连接这两个结点路径上边权的和。对于每个结点\(i\),它到其他\(n-1\)个结点都有一个距离,将这些距离从小到大排序,输出第\(k\)个距离。

思路:

重心剖分预处理每个重心管辖范围内从重心出发能够组成的所有距离。询问时二分答案\(k\),再对于每一级重心二分出\(<k\)的距离的个数。注意去重。

时间复杂度\(\mathcal O(n\log^3n)\)。

源代码:

#include<cstdio>
#include<cctype>
#include<vector>
#include<climits>
#include<algorithm>
inline int getint() {
register char ch;
while(!isdigit(ch=getchar()));
register int x=ch^'0';
while(isdigit(ch=getchar())) x=(((x<<2)+x)<<1)+(ch^'0');
return x;
}
const int N=1e5+1;
struct Graph {
struct Edge {
int to,w;
};
std::vector<Edge> e[N];
inline void add_edge(const int &u,const int &v,const int &w) {
e[u].push_back((Edge){v,w});
}
};
Graph g1,g2;
bool mark[N];
std::vector<int> v[N],v2[N];
int n,m,size[N],max[N],root,all;
void get_root(const int &x) {
max[x]=0;
size[x]=1;
mark[x]=true;
for(unsigned i=0;i<g1.e[x].size();i++) {
const int &y=g1.e[x][i].to;
if(mark[y]) continue;
get_root(y);
size[x]+=size[y];
max[x]=std::max(max[x],size[y]);
}
max[x]=std::max(max[x],all-size[x]);
if(max[x]<max[root]) root=x;
mark[x]=false;
}
inline void get_root(const int &x,const int &size) {
root=0;
all=size;
get_root(x);
}
void dfs(const int &x,const int &par,const int &dis,std::vector<int> &v,const bool type) {
if(!type) g2.add_edge(x,root,dis);
v.push_back(dis);
for(unsigned i=0;i<g1.e[x].size();i++) {
const int &y=g1.e[x][i].to;
if(y==par||mark[y]) continue;
dfs(y,x,dis+g1.e[x][i].w,v,type);
}
}
void solve(const int x) {
mark[x]=true;
dfs(x,0,0,v[x],0);
std::sort(v[x].begin(),v[x].end());
for(unsigned i=0;i<g1.e[x].size();i++) {
const int &y=g1.e[x][i].to;
if(mark[y]) continue;
get_root(y,size[y]);
dfs(y,x,g1.e[x][i].w,v2[root],1);
std::sort(v2[root].begin(),v2[root].end());
solve(root);
}
}
inline int ord(int x,int l) {
int ret=0;
for(register unsigned i=0;i<g2.e[x].size();i++) {
const int &y=g2.e[x][i].to;
ret+=std::lower_bound(v[y].begin(),v[y].end(),l-g2.e[x][i].w)-v[y].begin();
if(i+1!=g2.e[x].size()) ret-=std::lower_bound(v2[y].begin(),v2[y].end(),l-g2.e[x][i+1].w)-v2[y].begin();
}
return ret;
}
int main() {
max[0]=INT_MAX;
n=getint(),m=getint();
for(register int i=1;i<n;i++) {
const int u=getint(),v=getint(),w=getint();
g1.add_edge(u,v,w);
g1.add_edge(v,u,w);
}
get_root(1,n);
solve(root);
for(register int i=1;i<=n;i++) {
std::reverse(g2.e[i].begin(),g2.e[i].end());
}
for(register int i=1;i<=n;i++) {
int l=1,r=(n-1)*10000;
while(l<=r) {
const int mid=(l+r)>>1;
if(ord(i,mid)<=m) {
l=mid+1;
} else {
r=mid-1;
}
}
printf("%d\n",l-1);
}
return 0;
}

[BZOJ2051]A Problem For Fun/[BZOJ2117]Crash的旅游计划/[BZOJ4317]Atm的树的更多相关文章

  1. [BZOJ2117]Crash的旅游计划

    Description 眼看着假期就要到了,Crash由于长期切题而感到无聊了,因此他决定利用这个假期和好友陶陶一起出去旅游. Crash和陶陶所要去的城市里有N (N > 1) 个景点,Cra ...

  2. 【BZOJ2117】 [2010国家集训队]Crash的旅游计划

    [BZOJ2117] [2010国家集训队]Crash的旅游计划 Description 眼看着假期就要到了,Crash由于长期切题而感到无聊了,因此他决定利用这个假期和好友陶陶一起出去旅游. Cra ...

  3. BZOJ4317Atm的树&BZOJ2051A Problem For Fun&BZOJ2117[2010国家集训队]Crash的旅游计划——二分答案+动态点分治(点分树套线段树/点分树+vector)

    题目描述 Atm有一段时间在虐qtree的题目,于是,他满脑子都是tree,tree,tree…… 于是,一天晚上他梦到自己被关在了一个有根树中,每条路径都有边权,一个神秘的声音告诉他,每个点到其他的 ...

  4. BZOJ2117: [2010国家集训队]Crash的旅游计划

    裸点分,点分树每层维护有序表,查询二分,复杂度$O(nlog^3n)$. #include<bits/stdc++.h> #define M (u+v>>1) #define ...

  5. [2010国家集训队]Crash的旅游计划

    Description 眼看着假期就要到了,Crash由于长期切题而感到无聊了,因此他决定利用这个假期和好友陶陶一起出去旅游. Crash和陶陶所要去的城市里有N (N > 1) 个景点,Cra ...

  6. BZOJ 2117: [2010国家集训队]Crash的旅游计划 动态点分治+二分

    感觉现在写点分治可快了~ 二分答案,就可以将求第 $k$ 大转换成一个判断问题,直接拿点分树判断一下就行了. #include <cstdio> #include <vector&g ...

  7. Crash的旅行计划

    除草了.. Crash的旅行计划 [问题描述] 过不了多久,Crash就要迎来他朝思暮想的暑假.在这个暑假里,他计划着到火星上旅游.在火星上有N个旅游景点,Crash用1至N这N个正整数对这些景点标号 ...

  8. BZOJ2051——A Problem For Fun

    0.题意:给出一个N个结点的树,每条边有一个正整数权值,定义两个结点的距离为连接这两个结点路径上边权的和.对于每个结点i,它到其他N-1个结点都有一个距离,将这些距离从小到大排序,输出第K个距离. 1 ...

  9. BZOJ2051 : A Problem For Fun

    树的点分治,将点分治的过程记录下来,每一个分治结构按到分治中心的距离维护所有点. 对于一个点二分答案,然后在$O(\log n)$个分治结构中二分查找,时间复杂度$O(n\log^3n)$. #inc ...

随机推荐

  1. caffe源码阅读(1)_整体框架和简介(摘录)

    原文链接:https://www.zhihu.com/question/27982282 1.Caffe代码层次.回答里面有人说熟悉Blob,Layer,Net,Solver这样的几大类,我比较赞同. ...

  2. 【vim】实时加密文本 ggVGg?

    如果你不想让别人看懂你的屏幕上的内容,你可以使用一个内置的选项,通过下面的命令使用 ROT13 来对文本进行编码: ggVGg? gg 把光标移动到 Vim 缓冲区的第一行, V 进入可视模式, G ...

  3. 重装系统windows

    1 boot没有usb启动选项,驱动没加载好,先进入xp系统正确安装usb驱动,重启 2 file not fount bootmgr 用pe自带修复程序修复,修复驱动盘符为最小那个,非c盘 3 wi ...

  4. TYpeScript接口的使用

    1.接口中的属性值的使用: // 作用是强制类型检查 interface Iperson { name: string; age: string; } class Person { construct ...

  5. 域名调整 SEO优化(nginx)

    =============================================== 2019/3/31_第1次修改                       ccb_warlock == ...

  6. Java中的BlockingQueue队列

    BlockingQueue位于JDK5新增的concurrent包中,它很好地解决了多线程中,如何高效安全地“传输”数据的问题.通过这些高效并且线程安全的队列类,为我们快速搭建高质量的多线程程序带来极 ...

  7. Renderscript图像处理

    作者:慧能 最近正在学习renderscript,后期会整理一篇完整的文档,先记着.... https://blog.csdn.net/codemydream/article/details/5346 ...

  8. MACE(1)-----环境搭建

    作者:十岁的小男孩 QQ:929994365 无为 本文仅用于学习研究,非商业用途,欢迎大家指出错误一起学习,文章内容翻译自 MACE 官方手册,记录本人阅读与开发过程,力求不失原意,但推荐阅读原文. ...

  9. Codeforces 407B Long Path(好题 DP+思维)

    题目链接:http://codeforces.com/problemset/problem/407/B 题目大意:一共n+1个房间,一个人从1走到n+1,每次经过房间都会留下一个标记,每个房间有两扇门 ...

  10. python 全栈开发,Day90(Vue组件,前端开发工具包)

    昨日内容回顾 1. Vue使用 1. 生成Vue实例和DOM中元素绑定 2. app.$el --> 取出该vue实例绑定的DOM标签 3. app.$data --> 取出该vue实例绑 ...