Description

给定一个n个点,m条边的带权无向图,和起点S。请你选择一个点u(u!=S),使得在图中删掉点u 后,有尽可能多的点到S的最短距离改变。

Solution

先建出最短路DAG,在DAG中跑出灭绝树

灭绝树是一个点灭绝后子树中的点都灭绝的一棵树(灭绝在不同题目中意义不同)

先拓扑一下,每个点的最短路依赖的点就在它拓扑序前了

我们在拓扑序中从前往后扫

扫到点x,它的依赖点都已求出灭绝树父亲

x的灭绝树父亲就是它所有依赖点的灭绝树LCA

LCA可以用树上倍增求一下

Notice

1.可能有些点不连通

2.long long

Code

#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <cmath>
#include <cctype>
#include <algorithm>
using namespace std;
typedef long long LL;
const int M=200007;
const int E=600007;
inline int rd(){
int x=0;bool f=1;char c=getchar();
for(;!isdigit(c);c=getchar()) if(c=='-') f=0;
for(;isdigit(c);c=getchar()) x=x*10+c-48;
return f?x:-x;
} int n,m,S; struct node{int x,y;LL d;}ed[E]; int g[M],te;
struct edge{
int y,next;
LL d;
}e[E];
void addedge(int x,int y,LL z){
e[++te].y=y;
e[te].d=z;
e[te].next=g[x];
g[x]=te;
} int gd[M],td, gu[M],tu;
struct link{
int y,next;
}dw[E],up[E];
void adddw(int x,int y){
dw[++td].y=y;
dw[td].next=gd[x];
gd[x]=td;
}
void addup(int x,int y){
up[++tu].y=y;
up[tu].next=gu[x];
gu[x]=tu;
} int que[M],vis[M];
LL dis[M];
void inc(int &x){x++;if(x>=M)x=0;}
void spfa(int ss){
int h=0,t=1,x,p,y;
que[t]=ss;
memset(dis,127,sizeof(dis));
dis[ss]=0;
vis[ss]=1;
while(h^t){
inc(h); x=que[h];
for(p=g[x];p;p=e[p].next){
y=e[p].y;
if(dis[x]+e[p].d<dis[y]){
dis[y]=dis[x]+e[p].d;
if(!vis[y]){
vis[y]=1;
inc(t); que[t]=y;
}
}
}
vis[x]=0;//***********
}
} int indu[M];
void Dag(){
int i,x,y;
for(i=1;i<=m;i++){
x=ed[i].x;
y=ed[i].y;
if(dis[x]>dis[y]) swap(x,y);
if(dis[x]+ed[i].d==dis[y]){
adddw(x,y);
addup(y,x);
indu[y]++;
}
}
} void topu(){
int h=0,t=1,x,p,y;
que[1]=S;
while(h^t){
x=que[++h];
for(p=gd[x];p;p=dw[p].next){
y=dw[p].y;
indu[y]--;
if(indu[y]==0) que[++t]=y;
}
}
n=t;//排掉不连通的点*************************
} int pre[M][22];
int dep[M];
int sz[M];
int unit; int LCA(int x,int y){
if(dep[x]<dep[y]) swap(x,y);
int t;
for(t=unit;t>=0;t--){
if(dep[pre[x][t]]>=dep[y]) x=pre[x][t];
}
if(x==y) return x;
for(t=unit;t>=0;t--){
if(pre[x][t]!=pre[y][t]) x=pre[x][t], y=pre[y][t];
}
return pre[x][0];
} int main(){
int i,j,p,x,y,z;
n=rd(), m=rd(), S=rd();
for(i=1;i<=m;i++){
x=rd(),y=rd(),z=rd();
addedge(x,y,z);
addedge(y,x,z);
ed[i].x=x;
ed[i].y=y;
ed[i].d=(LL)z;
}
spfa(S);
Dag(); topu(); unit=(int)(log(n)/log(2))+1;
for(i=0;i<=unit;i++) pre[S][i]=S;
dep[S]=1;
for(i=2;i<=n;i++){
x=que[i];
z=0;
for(p=gu[x];p;p=up[p].next){
y=up[p].y;
if(!z) z=y;
else z=LCA(z,y);
}
pre[x][0]=z;
dep[x]=dep[z]+1;
for(j=1;j<=unit;j++) pre[x][j]=pre[pre[x][j-1]][j-1];
}
for(i=n;i>1;i--){
x=que[i];
sz[x]++;
sz[pre[x][0]]+=sz[x];
}
sz[S]++;//不是sz[1]++; int ans=0;
for(i=2;i<=n;i++)
ans=max(ans,sz[que[i]]);
printf("%d\n",ans);
return 0;
}

codeforces 757F - 最短路DAG+灭绝树的更多相关文章

  1. CF757F-Team Rocket Rises Again【最短路,DAG支配树】

    正题 题目链接:https://www.luogu.com.cn/problem/CF757F 题目大意 \(n\)个点\(m\)条边的一张无向图,求删除\(s\)以外的一个点改变\(s\)到最多点的 ...

  2. codeforces 757F Team Rocket Rises Again

    链接:http://codeforces.com/problemset/problem/757/F 正解:灭绝树. mdzz倍增lca的根节点深度必须是1..我因为这个错误调了好久. 我们考虑先求最短 ...

  3. bzoj 2815 灭绝树

    对于一个食物网(一个DAG),一个物种死亡后,某些物种就必然死亡,求出必然死亡的是那些物种. 灭绝树的另一种含义是:“灭绝树跟节点到节点u的路径上的节点由那些原图中从根节点到节点u的所有路径中都经过了 ...

  4. Codeforces 219D. Choosing Capital for Treeland (树dp)

    题目链接:http://codeforces.com/contest/219/problem/D 树dp //#pragma comment(linker, "/STACK:10240000 ...

  5. 最短路DAG

    边权皆为正时,有最短路DAG. 最短路DAG代表了从原点到每个点的所有最短路. 最短路树个数=最短路DAG生成树个数.用DAG生成树计数即可.复杂度\(O(n+m)\).

  6. [HAOI2012]道路(最短路DAG上计数)

    C国有n座城市,城市之间通过m条[b]单向[/b]道路连接.一条路径被称为最短路,当且仅当不存在从它的起点到终点的另外一条路径总长度比它小.两条最短路不同,当且仅当它们包含的道路序列不同.我们需要对每 ...

  7. Codeforces 633C Spy Syndrome 2 | Trie树裸题

    Codeforces 633C Spy Syndrome 2 | Trie树裸题 一个由许多空格隔开的单词组成的字符串,进行了以下操作:把所有字符变成小写,把每个单词颠倒过来,然后去掉单词间的空格.已 ...

  8. 【BZOJ4912】天才黑客(最短路,虚树)

    [BZOJ4912]天才黑客(最短路,虚树) 题面 BZOJ 洛谷 题解 \(Anson\)爷讲过的题目,然而我还是不会做 只有照着\(zsy\)的程序打我才会做....果然太弱了. 这道题目显然是把 ...

  9. codeforces Good bye 2016 E 线段树维护dp区间合并

    codeforces Good bye 2016 E 线段树维护dp区间合并 题目大意:给你一个字符串,范围为‘0’~'9',定义一个ugly的串,即串中的子串不能有2016,但是一定要有2017,问 ...

随机推荐

  1. Android驱动开发读书笔记六

    第六章 Linux 驱动的工作和访问方式是 Linux 的亮点之一,Linux 系统将每一个驱动都映射成一个文件.这些文件称为设备文件或驱动文件,都保存在/dev目录中,由于大多数Linux驱动都有与 ...

  2. ElasticSearch High Level REST API【1】文档基本操作

    获取ES客户端 ES的提供了四种Java客户端,分别为节点客户端(node client).传输客户端(Transport Client).低级REST客户端.高级REST客户端. 节点客户端作为集群 ...

  3. Apache 查找httpd.conf文件

    Linux下查找httpd.conf文件 $ find / -name httpd.conf  

  4. 2.在Cisco Packet Tracer里交换机默认网关的配置(实现跨网段telnet)

    我们将在此拓扑图的基础上进行实验 大多命令都可用tab键位来补齐 1.分别给pc机设置好ip地址 pc2为:192.168.1.1 pc3为:192.168.2.1 两台计算机处在不同的网段之中 2. ...

  5. JsRender (js模板引擎)

    最近学习了一下Jsrender模板渲染工具,非常不错,功能比较强大,官网说他是“简单直观 功能强大 可扩展的 快如闪电”确实如此.总结一下!! jsRender 三个最重要的概念:模板.容器和数据. ...

  6. 02.VUE学习二之数据绑定

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta http ...

  7. psutil模块的基础使用

    注:Python并没有自带psutil模块,需要自己去安装 安装psutil模块 pip install psutilorpip3 install psutil 一.导入模块 import psuti ...

  8. 51NOD 1128正整数分组V2 二分答案

    这道题是典型的二分答案法.但是首先难道这道题的时候我进行了一系列的思考,甚至联想到了之前多校中类似于树状划分的问题...原因是大家都包括N各节点K个输入.. 实际上最开始联想到了应当使用二分法“枚举” ...

  9. Intellij Idea 创建JavaWeb项目

    折腾Tomcat折腾了两个晚上,第一个晚上怎么都进不了Tomcat的首页,第二个晚上进去了,但是新建的Web项目,在浏览器中运行,总是 Error on Apache Tomcat: The requ ...

  10. synchronized同步方法和同步代码块的区别

    同步方法默认使用this或者当前类做为锁. 同步代码块可以选择以什么来加锁,比同步方法更精确,我们可以选择只有会在同步发生同步问题的代码加锁,而并不是整个方法. 同步方法使用synchronized修 ...