LINK:Spiders Evil Plan

非常巧妙的题目。

选出k条边使得这k条边的路径覆盖x且覆盖的边的边权和最大。

类似于桥那道题还是选择2k个点 覆盖x那么以x为根做长链剖分即可。

不过这样过不了。

还是考虑树的直径 可以发现覆盖x的那些点一定有一个是树的直径的两端之一。

所以我们直接对两条直径分别做这个东西然后想办法覆盖x.

如果y条边x还没被覆盖。

可以发现此时调整只有两种情况。

  1. 去掉长度最小的链然后把x所在的最长链加上去。

  2. 可以把x向上的被加入的链的下半部分去掉换成x.

由于边权不为1 所以无法直接跳长链。

考虑倍增即可。

const int MAXN=100010;
int n,len,Q;
int Log[MAXN];
int lin[MAXN],ver[MAXN<<1],nex[MAXN<<1],e[MAXN<<1];
inline void add(int x,int y,int z)
{
ver[++len]=y;
nex[len]=lin[x];
lin[x]=len;
e[len]=z;
}
struct wy
{
int d[MAXN],dis[MAXN],son[MAXN],mx[MAXN],ans[MAXN],c[MAXN];
int f[MAXN][20],cnt,rt,maxx;;
pii s[MAXN];
inline void dfs(int x,int fa,int op)
{
if(op)
{
f[x][0]=fa;mx[x]=dis[x];
d[x]=d[fa]+1;
rep(1,Log[d[x]],i)f[x][i]=f[f[x][i-1]][i-1];
}
if(!op&&dis[x]>dis[rt]){rt=x;}
go(x)
{
if(tn==fa)continue;
dis[tn]=dis[x]+e[i];
dfs(tn,x,op);
if(op&&mx[tn]>mx[x])
{
mx[x]=mx[tn];
son[x]=tn;
}
}
}
inline void dp(int x,int fa)
{
if(x==fa){s[++cnt]=mk(mx[x]-dis[f[x][0]],x);}
if(son[x])dp(son[x],fa);
go(x)if(tn!=f[x][0]&&tn!=son[x])dp(tn,tn);
}
inline void init(int x)
{
dfs(x,0,0);dis[rt]=0;
dfs(rt,0,1);dp(rt,rt);
sort(s+1,s+cnt+1);
for(int i=1,j=cnt;i<=cnt;++i,--j)
{
ans[i]=ans[i-1]+s[j].F;
for(int k=s[j].S;k;k=son[k])c[k]=i;
}
}
inline int calc1(int x,int y)//x所在长链替换y-1条长链
{
--y;
int w=x;
fep(Log[d[w]],0,i)if(c[f[w][i]]>y)w=f[w][i];
w=f[w][0];return ans[y]+mx[x]-dis[w];
}
inline int calc2(int x,int y)//向上的第一个长链的下半部分被替换掉.
{
int w=x;
fep(Log[d[x]],0,i)if(c[f[w][i]]>y)w=f[w][i];
w=f[w][0];return ans[y]+mx[x]-mx[w];
}
inline int query(int x,int y)
{
y=y*2-1;
if(y>=cnt)return ans[cnt];
if(c[x]<=y)return ans[y];
return max(calc1(x,y),calc2(x,y));
} }t[2];
int main()
{
freopen("1.in","r",stdin);
get(n);get(Q);
rep(2,n,i)
{
int get(x),get(y),get(z);
add(x,y,z);add(y,x,z);
Log[i]=Log[i>>1]+1;
}
t[0].init(1);t[1].init(t[0].rt);
int ans=0;
rep(1,Q,i)
{
int x,y;
get(x);get(y);
x=(x+ans-1)%n+1;
y=(y+ans-1)%n+1;
ans=max(t[0].query(x,y),t[1].query(x,y));
put(ans);
}
return 0;
}

CF Contest 526 G. Spiders Evil Plan 长链剖分维护贪心的更多相关文章

  1. 【BZOJ3252】攻略(长链剖分,贪心)

    [BZOJ3252]攻略(长链剖分,贪心) 题面 BZOJ 给定一棵树,每个点有点权,选定\(k\)个叶子,满足根到\(k\)个叶子的所有路径所覆盖的点权和最大. 题解 一个假装是对的贪心: 每次选择 ...

  2. bzoj 3252 攻略 长链剖分思想+贪心

    攻略 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 889  Solved: 423[Submit][Status][Discuss] Descrip ...

  3. 7.28 NOI模拟赛 H2O 笛卡尔树 并查集 贪心 长链剖分

    LINK:H2O 这场比赛打的稀烂 爆蛋. 只会暴力.感觉暴力细节比较多不想写. 其实这道题的难点就在于 采取什么样的策略放海绵猫. 知道了这一点才能确定每次放完海绵猫后的答案. 暴力枚举是不行的.而 ...

  4. 【CF1009F】Dominant Indices(长链剖分)

    [CF1009F]Dominant Indices(长链剖分) 题面 洛谷 CF 翻译: 给定一棵\(n\)个点,以\(1\)号点为根的有根树. 对于每个点,回答在它子树中, 假设距离它为\(d\)的 ...

  5. Codeforces 526G - Spiders Evil Plan(长链剖分+直径+找性质)

    Codeforces 题目传送门 & 洛谷题目传送门 %%%%% 这题也太神了吧 storz 57072 %%%%% 首先容易注意到我们选择的这 \(y\) 条路径的端点一定是叶子节点,否则我 ...

  6. 【CF526G】Spiders Evil Plan(贪心)

    [CF526G]Spiders Evil Plan(贪心) 题面 洛谷 CodeForces 给定一棵树,要求选择\(y\)条链,满足被链覆盖的所有点在树上联通,且\(x\)必定在联通块中. 对于每次 ...

  7. [CF526G]Spiders Evil Plan

    题目大意: 给出一个$n(n\leq 10^5)$个结点的带边权的树,$q(q\leq 10^5)$个询问,每次询问用$y$条路径覆盖整棵树且覆盖$x$至少一次,最多能覆盖的道路长度是多少? 强制在线 ...

  8. Codeforces 526G Spiders Evil Plan

    由于做的时候看的是中文题面,第一遍写就被卡题意了:还以为每一条都要过x,那么就是一道动态树根选择2y个叶子的奇怪题目 交完0分gg,才发现题目看错了╮(╯▽╰)╭ the node containin ...

  9. 【Cf Edu #47 F】Dominant Indices(长链剖分)

    要求每个点子树中节点最多的层数,一个通常的思路是树上启发式合并,对于每一个点,保留它的重儿子的贡献,暴力扫轻儿子将他们的贡献合并到重儿子里来. 参考重链剖分,由于一个点向上最多只有$log$条轻边,故 ...

随机推荐

  1. POJ1328贪心

    题意:如今我们位于沿海地区,需要安装大炮,使得火力可以覆盖整个区域.海岸线可以视为是无限长的直线.陆地位于海岸线的一侧,海洋位于另一侧.海洋里有若干个岛屿,每个小岛可以视为海洋中的一个点.我们需要在海 ...

  2. RocketMQ延迟消息的代码实战及原理分析

    RocketMQ简介 RocketMQ是一款开源的分布式消息系统,基于高可用分布式集群技术,提供低延时的.高可靠.万亿级容量.灵活可伸缩的消息发布与订阅服务. 它前身是MetaQ,是阿里基于Kafka ...

  3. PE文件格式详解(七)

    PE文件格式详解(七)   Ox00 前言 前面好几篇在讲输入表,今天要讲的是输出表和地址的是地址重定位.有了前面的基础,其实对于怎么找输出表地址重定位的表已经非常熟悉了.   0x01 输出表结构 ...

  4. SpringCloud和SpringBoot对应的版本选型

    SpringBoot版本选择: 官网地址:https://spring.io/projects/spring-boot SpringBoot官方目前最新最稳定版:2.3.1,如果单独使用SpringB ...

  5. postman-7-前置请求脚本

    前面讲了,tests初如何校验请求之后返回值是否正确 那前置脚本,就是处理,请求之前接口该如何处理,什么时候会用到呢? 比如:接口字段time,需要填入时间,而且这个是需要当前时间的,: 需要达到自动 ...

  6. Linux多任务编程之一:任务、进程、线程(转)

    来源:CSDN  作者:王文松  转自:Linux公社 Linux下多任务介绍 首先,先简单的介绍一下什么叫多任务系统?任务.进程.线程分别是什么?它们之间的区别是什么?,从而可以宏观的了解一下这三者 ...

  7. 接口测试基础——session认证和token认证

    总算是把这个过程理清楚了,现在我们的思路是:what?why?How?,实际上这些个机制产生的内部逻辑是从下至上的的:遇到问题了,想办法解决,总结归纳并取名.从解决一些小问题开始生长,不断打补丁直至完 ...

  8. 03 Vue实例成员

    Vue实例 1.el:实例 new Vue({ el: '#app' }) // 实例与页面挂载点一一对应 // 一个页面中可以出现多个实例对应多个挂载点 // 实例只操作挂载点内部内容 2.data ...

  9. mysql 漏洞利用与提权

    判断MySQL服务运行的权限 1.查看系统账号,如果出现MySQL这类用户,意味着系统可能出现了降权. 2.看mysqld运行的priority值. 3.查看端口是否可外联. MySQL密码获取与破解 ...

  10. java 面向对象(三):类结构 属性

    类的设计中,两个重要结构之一:属性 对比:属性 vs 局部变量 1.相同点: * 1.1 定义变量的格式:数据类型 变量名 = 变量值 * 1.2 先声明,后使用 * 1.3 变量都其对应的作用域 2 ...