传送门(权限)

题目大意

给定一个有向无环图,可以删去一个点和所有与它相连的边,使得图的其余部分最长路径最小,求这个位置和最小的最长路径长度。

题解

对于每一条边$u\rightarrow v$,设$F_u$表示从任意位置出发到达$u$的最多边数,设$G_v$表示从$v$出发到达任意位置的最多边数,那么最长链即为$\max\{F_u+G_v+1\}$。

考虑删掉点$x$。

对于字拓扑序在$x$之前的$y$,那么一定有一条链长度为$F_y$,拓扑序在$x$之后的$y$一定有一条长度为$G_y$的链。对于拓扑序和$x$属于并列关系的$y$,和它相邻的所有边一定$(u\rightarrow v)$,其中$u=y$或$v=y$,显然存在$F_u+G_v+1$的链。

那么按照拓扑序处理每一个点,维护一个集合$S$表示当前有效的链。

初始时$S$只用所有$G_x$,按照顺序拓扑序序枚举点$x$,然后删去它新失效的边是所有$(u\rightarrow x)$的边的$F_u+G_x+1$以及$G_x$,这时集合内的元素的最大值就是最长链的长度。然后删去它之后生效的边是所有$(x\rightarrow v)$的$F_x+G_v+1$,因为要确保接下来的拓扑序相互并列的两个点能够相互更新,不难发现删去所有它的后继节点后这些$x\rightarrow v$的$F_x+G_v+1$会自行删除。

在所有的答案中取最小值顺便记录位置即可。

#include<algorithm>
#include<iostream>
#include<cstring>
#include<cstdio>
#include<cmath>
#include<queue>
#define LL long long
#define M 500020
using namespace std;
const int BS=(1<<20)+5; char Buffer[BS],*HD,*TL;
char Getchar(){if(HD==TL){TL=(HD=Buffer)+fread(Buffer,1,BS,stdin);} return (HD==TL)?EOF:*HD++;}
int read(){
int nm=0,fh=1; char cw=Getchar();
for(;!isdigit(cw);cw=Getchar()) if(cw=='-') fh=-fh;
for(;isdigit(cw);cw=Getchar()) nm=nm*10+(cw-'0');
return nm*fh;
}
int n,m,fs[M][2],nt[M<<1][2],to[M<<1][2],otd[M][2];
int q[M],hd,tl,,ans,pos,tmp,dis[M][2];
priority_queue<int> Q,D;
inline void rw(){while((!D.empty())&&D.top()==Q.top()) Q.pop(),D.pop();}
#define del(a) D.push(a),rw()
#define ins(a) Q.push(a)
#define tp Q.top()
void link(int x,int y){
nt[tmp][0]=fs[x][0],nt[tmp][1]=fs[y][1],otd[x][0]++,otd[y][1]++;
to[tmp][0]=y,to[tmp][1]=x,fs[x][0]=fs[y][1]=tmp,tmp++;
}
int DP(int x,int kd){
if(!otd[x][kd]) return 0; if(dis[x][kd]) return dis[x][kd];
for(int i=fs[x][kd];i!=-1;i=nt[i][kd]) dis[x][kd]=max(dis[x][kd],DP(to[i][kd],kd));
++dis[x][kd]; return dis[x][kd];
}
int main(){
n=read(),m=read(),memset(fs,-1,sizeof(fs)),ans=n-1,pos=1;
for(int i=1;i<=m;i++){int x=read(),y=read();link(x,y);}
for(int i=1;i<=n;i++) DP(i,0),DP(i,1),ins(dis[i][0]);
for(int i=1;i<=n;i++) if(!otd[i][1]) q[tl++]=i;
while(hd<tl){
int x=q[hd++],maxn; del(dis[x][0]);
for(int i=fs[x][1];i!=-1;i=nt[i][1]) del(dis[to[i][1]][1]+dis[x][0]+1);
maxn=tp; if(maxn<ans) ans=maxn,pos=x; ins(dis[x][1]);
for(int i=fs[x][0];i!=-1;i=nt[i][0]){
ins(dis[to[i][0]][0]+dis[x][1]+1);
if(!(--otd[to[i][0]][1])) q[tl++]=to[i][0];
}
}printf("%d %d\n",pos,ans); return 0;
}

  

BZOJ3832 Rally的更多相关文章

  1. POI2014

    ...一个shabi和一堆神题的故事 今天只写了两道 之后随缘更吧 啊 顺便 snake我是不会更的 bzoj3829 POI2014 Farmcraft mhy住在一棵有n个点的树的1号结点上,每个 ...

  2. 【BZOJ3832】[POI2014]Rally(拓扑排序,动态规划)

    [BZOJ3832][POI2014]Rally(拓扑排序,动态规划) 题面 BZOJ,权限题 洛谷 题解 这题好强啊,感觉学了好多东西似的. 首先发现了一个图画的很好的博客,戳这里 然后我来补充一下 ...

  3. 【BZOJ-3832】Rally 拓扑序 + 线段树 (神思路题!)

    3832: [Poi2014]Rally Time Limit: 20 Sec  Memory Limit: 128 MBSec  Special JudgeSubmit: 168  Solved:  ...

  4. BZOJ3832[Poi2014]Rally——权值线段树+拓扑排序

    题目描述 An annual bicycle rally will soon begin in Byteburg. The bikers of Byteburg are natural long di ...

  5. 【bzoj3832】Rally

    Portal -->bzoj3832 Description ​ 给你一个DAG,每条边长度都是\(1\),请找一个点满足删掉这个点之后剩余图中的最长路最短 Solution ​​ 这题的话感觉 ...

  6. BZOJ3832 [Poi2014]Rally 【拓扑序 + 堆】

    题目链接 BZOJ3832 题解 神思路orz,根本不会做 设\(f[i]\)为到\(i\)的最长路,\(g[i]\)为\(i\)出发的最长路,二者可以拓扑序后\(dp\)求得 那么一条边\((u,v ...

  7. BZOJ3832 : [Poi2014]Rally

    f[0][i]为i出发的最长路,f[1][i]为到i的最长路 新建源汇S,T,S向每个点连边,每个点向T连边 将所有点划分为两个集合S与T,一开始S中只有S,其它点都在T中 用一棵线段树维护所有连接属 ...

  8. BZOJ3832: [Poi2014]Rally(拓扑排序 堆)

    题意 题目链接 Sol 最直观的思路是求出删除每个点后的最长路,我们考虑这玩意儿怎么求 设\(f[i]\)表示以\(i\)结尾的最长路长度,\(g[i]\)表示以\(i\)开始的最长路长度 根据DAG ...

  9. 并不对劲的bzoj3832: [Poi2014]Rally

    传送门-> 这题的原理看上去很神奇. 称拓扑图中入度为0的点为“起点”,出度为0的点为“终点”. 因为“起点”和“终点”可能有很多个,算起来会很麻烦,所以新建“超级起点”S,向所有点连边,“超级 ...

随机推荐

  1. MySQL数据库(3)_MySQL数据库表记录操作语句

    附: MYSQL5.7版本sql_mode=only_full_group_by问题 .查询当前sql_mode: select @@sql_mode .查询出来的值为: set @@sql_mode ...

  2. (转) GIS 中地理坐标和屏幕坐标的标准转换方法

    from :http://www.cnblogs.com/WonKerr/archive/2010/01/01/Coord_Transform.html 在GIS中,当你拿到一个图层的地理坐标后,如果 ...

  3. iOS 系统认知 debug distribution release 和 #ifdef DEBUG

    debug:调试模式 有调试信息 线下 release: 无调试信息 经过了编译优化 发布 给用户使用的 线上模式  一般 工程项目 都是自带 上述两种配置结构 还有出现 distribution: ...

  4. HBase基本知识介绍及典型案例分析

    本次分享的内容主要分为以下五点: HBase基本知识: HBase读写流程: RowKey设计要点: HBase生态介绍: HBase典型案例分析. 首先我们简单介绍一下 HBase 是什么. HBa ...

  5. 40个你可能不知道的Python的特点和技巧

    1.拆箱 >>> a, b, c = 1, 2, 3 >>> a, b, c (1, 2, 3) >>> a, b, c = [1, 2, 3] ...

  6. 【TopCoder】SRM152 DIV2总结

    为什么平常刷的时候感觉还不错,比赛的时候只能做出来一道题=.= 250分题:大水题,根据题目规则把一个字符串翻译成数字,直接代码:GitHub 我是通过遍历一个个数出来的,看到大神的解法是把字符用‘- ...

  7. springmvc异常处理(非注解与注解)

    1.异常 程序中的异常一般分为两类:预期异常,运行时异常.前者是我们可预知的,我们一般通过捕获和抛出方式处理这些异常.后者主要通过代码规范.测试等手段来减少异常的发生.一般,我们在系统的DAO.Ser ...

  8. 【P2629】好消息,坏消息(前缀和+单调队列优化DP)

    一激动一颓就会忘了总结... 前面的大黄题就不总结了. 这个题我只想说一声艹,一开始的思路就是正确的,然后计算的时候有了一个瑕疵,不过很快也就改过来了.然后却一直连样例都过不了.仔仔细细看了老半天,经 ...

  9. window7 共享wifi(不通过wifi软件)

    1.新建共享网络账号 管理员登录cmd输入:netsh wlan set hostednetwork mode=allow ssid=4Gtest key=12345678 ssid是无线网络名称.k ...

  10. UOJ67 新年的毒瘤

    本文版权归ljh2000和博客园共有,欢迎转载,但须保留此声明,并给出原文链接,谢谢合作. 本文作者:ljh2000 作者博客:http://www.cnblogs.com/ljh2000-jump/ ...