洛谷P3387缩点
传送门
有向图。。
代码中有两种方法,拓扑排序和记忆化搜索
#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <queue>
#define re register
using namespace std ;
const int maxn = 1e5 + 4 ;
inline int read () {
int f = 1 , x = 0 ;
char ch = getchar () ;
while(ch > '9' || ch < '0') {if(ch == '-') f = -1 ; ch = getchar () ;}
while(ch >= '0' && ch <= '9') {x = (x << 1) +(x << 3) + ch - '0' ; ch = getchar () ;}
return x * f;
}
int n , m , a[maxn] , u , v , ans ;
int head[maxn] , tot , head2[maxn] , tot2 ;
struct Edge {
int from , to , next ;
}edge[maxn << 1] , edge2[maxn] ;
inline void add(int u , int v) {
edge[++tot].from = u ;
edge[tot].to = v ;
edge[tot].next =head[u] ;
head[u] = tot ;
}
inline void add2(int u , int v) {
edge2[++tot2].from = u ;
edge2[tot2].to = v;
edge2[tot2].next = head2[u];
head2[u] = tot2;
}
int stack[maxn] , belong[maxn] , top , cnt , num[maxn] ;
int low[maxn] , dfn[maxn] , ind , dis[maxn] ;
bool ins[maxn] ;
inline void tarjan(int x) {
dfn[x] = low[x] = ++ind;
stack[++top] = x ;
ins[x] = true ;
for(re int i = head[x] ; i; i = edge[i].next) {
int v = edge[i].to ;
if(!dfn[v]) {
tarjan(v) ;
low[x] = min(low[x] , low[v]);
}
if(ins[v]) {
low[x] = min(low[x] , dfn[v]);
}
}
int k = 0;
if(dfn[x] == low[x]) {
++cnt;
do{
k = stack[top];
top--;
ins[k] = false;
num[cnt]++;
dis[cnt] += a[k];
belong[k] = cnt;
}while (k != x);
}
}
queue<int> q;
int dis2[maxn] , in[maxn] ;
inline int topo() {
for(re int i = 1 ; i <= cnt ; ++ i)
if(!in[i]) {
q.push(i);
dis2[i] = dis[i];
}
while(!q.empty()) {
int cur = q.front();
q.pop() ;
for(re int i = head2[cur] ; i ; i = edge2[i].next) {
int v = edge2[i].to ;
dis2[v] = max(dis2[v] , dis2[cur] + dis[v]) ;
in[edge2[i].to]-- ;
if(!in[edge2[i].to])
q.push(edge2[i].to) ;
}
}
for(re int i = 1 ; i <= n ; ++ i)
ans = max(ans , dis2[i]) ;
return ans;
}
int main () {
n = read () ; m =read() ;
for(re int i = 1 ; i <= n ; ++ i)
a[i] = read () ;
for(re int i = 1 ; i <= m ; ++ i) {
u = read () ; v = read () ;
add(u , v) ;
}
for(re int i = 1 ; i <= n ; ++ i)
if(!dfn[i]) tarjan(i) ;
for(re int i = 1 ; i <= tot ; ++ i) {
if(belong[edge[i].from] != belong[edge[i].to]) {
add2(belong[edge[i].from] , belong[edge[i].to]) ;
in[belong[edge[i].to]]++ ;
}
}
printf("%d\n" , topo()) ;
return 0 ;
}
洛谷P3387缩点的更多相关文章
- 洛谷P3387 缩点模板
给定一个n个点m条边有向图,每个点有一个权值,求一条路径,使路径经过的点权值之和最大.你只需要求出这个权值和. 允许多次经过一条边或者一个点,但是,重复经过的点,权值只计算一次. 因为可以重复经过点, ...
- 洛谷P3387 【模板】缩点 题解
背景 今天\(loj\)挂了,于是就有了闲情雅致来刷\(luogu\) 题面 洛谷P3387 [模板]缩点传送门 题意 给定一个\(n\)个点\(m\)条边有向图,每个点有一个权值,求一条路径,使路径 ...
- 洛谷 P3387 【模板】缩点 DAGdp学习记
我们以洛谷P3387 [模板]缩点 来学习DAGdp 1.这道题的流程 //伪代码 for i->n if(i未被遍历) tarjan(i) 缩点() DAGdp() 完成 首先tarjan这部 ...
- tarjan缩点练习 洛谷P3387 【模板】缩点+poj 2186 Popular Cows
缩点练习 洛谷 P3387 [模板]缩点 缩点 解题思路: 都说是模板了...先缩点把有环图转换成DAG 然后拓扑排序即可 #include <bits/stdc++.h> using n ...
- 洛谷——P3387 【模板】缩点
P3387 [模板]缩点 题目背景 缩点+DP 题目描述 给定一个n个点m条边有向图,每个点有一个权值,求一条路径,使路径经过的点权值之和最大.你只需要求出这个权值和. 允许多次经过一条边或者一个点, ...
- 【模板】缩点(Tarjan算法)/洛谷P3387
题目链接 https://www.luogu.com.cn/problem/P3387 题目大意 给定一个 \(n\) 个点 \(m\) 条边有向图,每个点有一个权值,求一条路径,使路径经过的点权值之 ...
- 洛谷P3387 【模板】缩点
题目背景 缩点+DP 题目描述 给定一个n个点m条边有向图,每个点有一个权值,求一条路径,使路径经过的点权值之和最大.你只需要求出这个权值和. 允许多次经过一条边或者一个点,但是,重复经过的点,权值只 ...
- 洛谷 P3387 【模板】缩点
题目背景 缩点+DP 题目描述 给定一个n个点m条边有向图,每个点有一个权值,求一条路径,使路径经过的点权值之和最大.你只需要求出这个权值和. 允许多次经过一条边或者一个点,但是,重复经过的点,权值只 ...
- 洛谷 P3387 题解
题面 裸跑一遍SPFA,统计每个点的入队次数: 如果该点的入队次数>=总点数,那么该点便是一个负环上的点: 重点!!!: 1.不是“YES”,是“YE5”: 2.不是“NO”,是“N0”:(是零 ...
随机推荐
- 主流图片加载框架 ImageLoader、Glide、Picasso、Fresco 对比
图片缓存库主页: Glidehttps://github.com/bumptech/glide fresco - An Android library for managing images and ...
- centos详细安装redis步骤
1. 从官网(http://redis.io)下载最新稳定版2. 使用命令解压下载的tar包:tar –zxvf redis-3.2.0.tar.gz3. 通过命令cd redis-3.2.0进入源码 ...
- 约瑟夫环问题算法(M)
http://blog.csdn.net/zhuimengzh/article/details/6727221 用户输入M,N值,从1至N开始顺序循环数数,每数到M输出该数值,直至全部输出.写出C程序 ...
- 四、java面向对象编程_2
目录 六.对象的创建和使用 七.this关键字 八.static关键字 九.package和import语句 十.类的继承 十一.访问控制 十二.方法的重写 十三.super关键字 十四.继承中的构造 ...
- 《编程快速上手》--web抓取--利用webbrowser模块的mapIT.py
1.代码如下 #! python3 # mapIT.py - Launches a map in the browser using an address from the # command lin ...
- css基础--常用css属性01
1 背景相关 背景颜色 background-color = 颜色名称/rgb值/十六进制值 背景图片 background-image = url('') 背景图片平铺方式 backgro ...
- Java基础-面向接口编程-JDBC详解
Java基础-面向接口编程-JDBC详解 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.JDBC概念和数据库驱动程序 JDBC(Java Data Base Connectiv ...
- Excel 之 字符串截取、拼接、和透视表
假设有表如下: 如何得到E列的数据(格式为模式名.表名,如PDM_DATA.T05_GMS_NAV_SPV_PCH_RDM_TRX_EVT)?如何由E列得到F列数据(从E类中截取表名)? 1. 字符串 ...
- IOS的__bridge
使用 __bridge 关键字来实现id类型与void*类型的相互转换.看下面的例子. id obj = [[NSObject alloc] init]; void *p = (__bridge vo ...
- bzoj千题计划171:bzoj2456: mode
http://www.lydsy.com/JudgeOnline/problem.php?id=2456 任意删除序列中两个不同的数,众数仍然是众数 不停的删,剩下的最后的数一定是众数 具体实现: 记 ...