题意

\(n(2 \le n \le 500000)\)个点\(m(1 \le m \le 1000000)\)条边的有向无环图,找到一个点,使得删掉这个点后剩余图中的最长路径最短。

分析

神题不会做。

题解

首先我们新建个源\(s\)和汇\(t\),连边\(s->i, i->t\),最远距离分别为\(d[i, 0]\)和\(d[i, 1]\),则一个图中的最长链就是\(max(d[u, 0]+d[v, 1]-1, \exists edge(u, v))\),再由于图中任意一个\(s-t\)割都会有最长链的边,那么问题就转化为去掉\(x\)点及其相关的边后,在途中的一个割中找最大值。由于图是拓扑序的,所以,我们只要把某割点的入边拿掉后、拓扑秩在自己前或相同的点出边都加入到一个堆里,那么堆中就可以形成一个割!这个比较显然。

#include <bits/stdc++.h>
using namespace std;
inline int getint() {
int x=0;
char c=getchar();
for(; c<'0'||c>'9'; c=getchar());
for(; c>='0'&&c<='9'; x=x*10+c-'0', c=getchar());
return x;
}
const int N=500005;
int q[N], in[N], d[N][2], n, cnt1, cnt2, ihead1[N], ihead2[N], sz[N<<2];
struct E {
int next, to;
}e1[N<<2], e2[N<<2];
void add(int x, int y) {
e1[++cnt1]=(E){ihead1[x], y}; ihead1[x]=cnt1;
e2[++cnt2]=(E){ihead2[y], x}; ihead2[y]=cnt2;
++in[y];
}
void ins(int p, int d, int l=0, int r=n, int x=1) {
sz[x]+=d;
if(l==r) {
return;
}
int mid=(l+r)>>1;
p<=mid?ins(p, d, l, mid, x<<1):ins(p, d, mid+1, r, x<<1|1);
}
int ask(int l=0, int r=n, int x=1) {
if(l==r) {
return l;
}
int mid=(l+r)>>1, ls=x<<1, rs=ls|1;
return sz[rs]?ask(mid+1, r, rs):ask(l, mid, ls);
}
int main() {
n=getint();
int m=getint(), fr=0, ta=0;
for(int i=1; i<=m; ++i) {
int x=getint(), y=getint();
add(x, y);
}
for(int i=1; i<=n; ++i) {
if(!in[i]) {
q[ta++]=i;
}
}
while(fr!=ta) {
int x=q[fr++];
for(int i=ihead1[x]; i; i=e1[i].next) {
if(!--in[e1[i].to]) {
q[ta++]=e1[i].to;
}
}
}
for(int j=0; j<n; ++j) {
for(int x=q[j], i=ihead2[x]; i; i=e2[i].next) {
d[x][0]=max(d[x][0], d[e2[i].to][0]+1);
}
for(int x=q[n-j-1], i=ihead1[x]; i; i=e1[i].next) {
d[x][1]=max(d[x][1], d[e1[i].to][1]+1);
}
}
for(int i=1, S=n+1, T=S+1; i<=n; ++i) {
add(S, i);
add(i, T);
ins(d[i][1], 1);
}
d[n+1][0]=-1;
d[n+2][1]=-1;
int ans1=-1, ans2=n+1;
for(int j=0; j<n; ++j) {
int x=q[j], t;
for(int i=ihead2[x]; i; i=e2[i].next) {
ins(d[e2[i].to][0]+d[x][1]+1, -1);
}
if(ans2>(t=ask())) {
ans1=x;
ans2=t;
}
for(int i=ihead1[x]; i; i=e1[i].next) {
ins(d[x][0]+d[e1[i].to][1]+1, 1);
}
}
printf("%d %d\n", ans1, ans2);
return 0;
}

【BZOJ】3832: [Poi2014]Rally的更多相关文章

  1. 【BZOJ】3524: [Poi2014]Couriers

    [算法]主席树 [题解]例题,记录和,数字出现超过一半就递归查找. 主席树见[算法]数据结构 #include<cstdio> #include<algorithm> #inc ...

  2. 【BZOJ】3835: [Poi2014]Supercomputer

    题意 \(n(1 \le 1000000)\)个点的有根树,\(1\)号点为根,\(q(1 \le 1000000)\)次询问,每次给一个\(k\),每一次可以选择\(k\)个未访问的点,且父亲是访问 ...

  3. 【BZOJ】3526: [Poi2014]Card

    题意 \(n(n \le 200000)\)张卡片,正反有两个数\(a[i], b[i]\).\(m(m \le 1000000)\)次操作,每次交换\(c[i].d[i]\)位置上的卡片.每一次操作 ...

  4. 【BZOJ】3523: [Poi2014]Bricks

    题意 \(n(n \le 1000000)\)个物品,颜色分别为\(a[i]\),现在要求排在一排使得相邻两个砖块的颜色不同,且限定第一个砖块和最后一个砖块的颜色,输出一个合法解否则输出-1. 分析 ...

  5. 【BZOJ】3521: [Poi2014]Salad Bar

    题意 长度为\(n(1 \le n \le 1000000)\)的\(01\)字符串.找一个最长的连续子串\(S\),使得不管是从左往右还是从右往左取,都保证每时每刻已取出的\(1\)的个数不小于\( ...

  6. 【BZOJ】3834: [Poi2014]Solar Panels

    http://www.lydsy.com/JudgeOnline/problem.php?id=3834 题意:求$max\{(i,j)\}, smin<=i<=smax, wmin< ...

  7. BZOJ:3832: [Poi2014]Rally

    题意: 给出$DAG$,询问删掉哪个点之后最长路径最短 思路: 我们令$f[x]$表示从最远的点到达它的距离,$g[x]$表示它能够到达最远的点的距离 那么对于$(x -> y)$一条边来说,它 ...

  8. 【BZOJ】3524 [POI2014] Couriers(主席树)

    题目 传送门:QWQ 传送到洛谷QWQ 分析 把求区间第k大的改一改就ok了. 代码 #include <bits/stdc++.h> using namespace std; ; ], ...

  9. 【BZOJ】3052: [wc2013]糖果公园

    http://www.lydsy.com/JudgeOnline/problem.php?id=3052 题意:n个带颜色的点(m种),q次询问,每次询问x到y的路径上sum{w[次数]*v[颜色]} ...

随机推荐

  1. java中volatile关键字的含义

    在java线程并发处理中,有一个关键字volatile的使用目前存在很大的混淆,以为使用这个关键字,在进行多线程并发处理的时候就可以万事大吉. Java语言是支持多线程的,为了解决线程并发的问题,在语 ...

  2. C#之关机事件

    一.背景 做了个APP,通过向下位机发送串口数据,然后通过串口去控制多路光源,现在的问题来了,若是电脑强行关机,而APP又没在电脑关机前做任何动作,导致电脑已经关机了,而下位机控制的灯源还在工作.所以 ...

  3. PHP中静态(static)调用非静态方法详解

    1.PHP中可以静态调用非静态方法么? 今天我被问到PHP中可不可以使用 className::methodName() 的方法来调用一个没有声明static的方法.在我的印象中,我好像是见过这种用法 ...

  4. AJAX 请求区分 $_SERVER['HTTP_X_REQUESTED_WITH'] 小解

    关于这个内容,很多人都有所了解.但从我搜索的内容来看,他们只是略微看一下,根本不知道里面到底是什么情况. 受到很多模版代码的影响,大家都以为PHP有这样一个自定义变量:$_SERVER['HTTP_X ...

  5. Javascript闭包深入解析及实现方法

    1.什么是闭包 闭包,官方对闭包的解释是:一个拥有许多变量和绑定了这些变量的环境的表达式(通常是一个函数),因而这些变量也是该表达式的一部分.闭包的特点:1. 作为一个函数变量的一个引用,当函数返回时 ...

  6. jquery_DOM笔记

    回头补充知识: jquery事件复习: bind() 用于绑定多个事件,当某一个节点需要进行多项处理的时候使用 .使用方式 $(select).bind({event:function(),event ...

  7. Android多种进度条使用详解

    在这里,总结一下loading进度条的使用简单总结一下. 一.说起进度条,必须说说条形进度条,经常都会使用到嘛,特别是下载文件进度等等,还有像腾讯QQ安装进度条一样,有个进度总给人良好的用户体验. 先 ...

  8. @好友的EditText

    类似微信聊天中的@好友功能,封装到一个EditText中,gist打不开了,直接贴代码到这里吧: /*** @好友的输入组件*/public class AtEditText extends Edit ...

  9. 配置nginx+php

    一般这样配置 此时很多教程会教大家这样配置Nginx+PHP: server { listen 80; server_name foo.com; root /path; location / { in ...

  10. windows网络编程

    1.协议的特征 面向消息的和基于流的 面向连接的和面向无连接的 2.端口分为三类:“已知”端口.已注册端口.动态和私用端口 0~1023 IANA控制,为固定服务保留的 1024~49151 已注册端 ...