裸点分,点分树每层维护有序表,查询二分,复杂度$O(nlog^3n)$。

#include<bits/stdc++.h>
#define M (u+v>>1)
#define pb push_back
#define FOR(i,v)\
for(int i=0;i!=v.size();++i)
using namespace std;
void eq2(int&x,int y){x=x<y?y:x;}
const int N=1e5+5;
typedef int arr[N];
arr r,z,p,d,c[18];
typedef vector<int>lis;
typedef lis arc[N];
arc e1,e2,e3,f1,f2;
#define j e1[u][i]
void dfs1(int u,int v){
r[u]=1;
FOR(i,e1[u])
if(j^v&&!z[j])
dfs1(j,u),r[u]+=r[j];
}
int dfs2(int u,int v,int k){
int s=k-r[u];
FOR(i,e1[u])
if(j^v&&!z[j]){
if(int l=dfs2(j,u,k))return l;
eq2(s,r[j]);
}
return s*2<=k?u:0;
}
int dfs3(int u){
dfs1(u,0),u=dfs2(u,0,r[u]);
z[u]=1;
FOR(i,e1[u])
if(!z[j])e3[u].pb(dfs3(j));
return u;
}
void dfs4(int u,int v,int*f){
FOR(i,e1[u])
if(j^v&&z[j])
f[j]=f[u]+e2[u][i],dfs4(j,u,f);
}
void dfs5(int u,int v,int*f,lis&s){
s.pb(f[u]);
FOR(i,e1[u])
if(j^v&&z[j])dfs5(j,u,f,s);
}
#undef j
#define j e3[u][i]
void pre(lis&s){sort(s.begin(),s.end());}
void dfs6(int u){
int*s=c[d[u]];
dfs4(u,0,s),dfs5(u,0,s,f1[u]),pre(f1[u]),z[u]=0;
FOR(i,e3[u])
dfs5(j,0,s,f2[j]),pre(f2[j]),d[j]=d[p[j]=u]+1,dfs6(j);
}
#undef j
int ask(lis&s,int v){return upper_bound(s.begin(),s.end(),v)-s.begin();}
int ask(int s,int t){
int i=s,j=d[s],k=ask(f1[s],t)-1;
for(;j--;i=p[i])
k+=ask(f1[p[i]],t-c[j][s])-ask(f2[i],t-c[j][s]);
return k;
}
int main(){
int n,k,u,v,w;
scanf("%*s%d%d",&n,&k);
for(int i=2;i<=n;++i){
scanf("%d%d%d",&u,&v,&w);
e1[u].pb(v),e1[v].pb(u);
e2[u].pb(w),e2[v].pb(w);
}
dfs6(dfs3(1));
for(int i=1;i<=n;++i){
u=0,v=1e9;
while(u^v)ask(i,M)<k?u=M+1:v=M;
printf("%d\n",v);
}
}

BZOJ2117: [2010国家集训队]Crash的旅游计划的更多相关文章

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

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

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

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

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

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

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

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

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

    [BZOJ2051]A Problem For Fun/[BZOJ2117]Crash的旅游计划/[BZOJ4317]Atm的树 题目大意: 给出一个\(n(n\le10^5)\)个结点的树,每条边有 ...

  6. [国家集训队] Crash 的文明世界(第二类斯特林数)

    题目 [国家集训队] Crash 的文明世界 前置 斯特林数\(\Longrightarrow\)斯特林数及反演总结 做法 \[\begin{aligned} ans_x&=\sum\limi ...

  7. 洛谷 P1829 [国家集训队]Crash的数字表格 / JZPTAB 解题报告

    [国家集训队]Crash的数字表格 / JZPTAB 题意 求\(\sum\limits_{i=1}^n\sum\limits_{j=1}^mlcm(i,j)\),\(n,m\le 10^7\) 鉴于 ...

  8. [Luogu P1829] [国家集训队]Crash的数字表格 / JZPTAB (莫比乌斯反演)

    题面 传送门:洛咕 Solution 调到自闭,我好菜啊 为了方便讨论,以下式子\(m>=n\) 为了方便书写,以下式子中的除号均为向下取整 我们来颓柿子吧qwq 显然,题目让我们求: \(\l ...

  9. 题解-[国家集训队]Crash的数字表格 / JZPTAB

    题解-[国家集训队]Crash的数字表格 / JZPTAB 前置知识: 莫比乌斯反演 </> [国家集训队]Crash的数字表格 / JZPTAB 单组测试数据,给定 \(n,m\) ,求 ...

随机推荐

  1. ArcGIS Engine开发之地图基本操作(1)

    ArcGIS提供的各类数据形式以及相应接口 1. 空间数据 在GIS软件中,空间数据有多种不同的形式存在.按照不同的划分标准可以分为矢量数据和栅格数据.GIS格式数据和非GIS格式数据(CAD格式). ...

  2. swift-字符和字符串

    OC定义字符: char charValue = 'a'; swift定义字符: var charValue : Character = "a" Unicode 国际标准的文本编码 ...

  3. ORACLE 博客文章目录(2015-05-27更新)

    从接触ORACLE到深入学习,已有好几年了,虽然写的博客不多,质量也参差不齐,但是,它却是成长的历程的点点滴滴的一个见证,见证了我在这条路上的寻寻觅觅,朝圣的心路历程,现在将ORACLE方面的博客整理 ...

  4. C# 调用 Oracle

    C# 调用 Oracle 是如此尴尬 >System.Data.OracleClient.dll —— .Net 自带的 已经 过时作废. >要链接 Oracle 服务器,必须在 本机安装 ...

  5. Masonry和FDTemplateLayoutCell 结合使用示例Demo

    我们知道,界面布局可以用Storyboard或Xib结合Autolayout实现,如果用纯代码布局,比较热门的有Masonry.SDAutoLayout,下面的简单demo,采用纯代码布局,实现不定高 ...

  6. 通过中看不中用的代码分析Ioc容器,依赖注入....

    /** * 通过生产拥有超能力的超人实例 来理解IOC容器 */ //超能力模组接口 interface SuperModuleInterface{ public function activate( ...

  7. Quartz框架

    Quartz框架 Quartz 是个开源的作业调度框架,为在 Java 应用程序中进行作业调度提供了简单却强大的机制.Quartz 允许开发人员根据时间间隔(或天)来调度作业.它实现了作业和触发器的多 ...

  8. 监控系统Opserver的配置调试

    Stack Exchange开源其监控系统Opserver有一段时间了.之前在项目中用过他们的MiniProfile来分析页面执行效率和帮助新人了解项目,当他们开源了其监控系统的时候正好部门也在关注监 ...

  9. C#代码中实现两个表(DataTable)的关联查询(JOIN)

    之前通常都是使用SQL直接从数据库中取出表1和表2关联查询后的数据,只需要用一个JOIN就可以了,非常方便.近日遇到一种情况,两个表中的数据已经取到代码中,需要在代码中将这两个表关联起来,并得到它们横 ...

  10. 撸一段 SQL ? 还是撸一段代码?

    记得刚入公司带我的研发哥们能写一手漂亮的 SQL,搜索准确.执行快.效率高. 配合Web项目中的查询展示数据的需求,基本是分分钟完成任务. 那段时间基本是仰视的态度,每天都去讨教一点手写 SQL 的要 ...