传送门

有向图。。

代码中有两种方法,拓扑排序和记忆化搜索

#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缩点的更多相关文章

  1. 洛谷P3387 缩点模板

    给定一个n个点m条边有向图,每个点有一个权值,求一条路径,使路径经过的点权值之和最大.你只需要求出这个权值和. 允许多次经过一条边或者一个点,但是,重复经过的点,权值只计算一次. 因为可以重复经过点, ...

  2. 洛谷P3387 【模板】缩点 题解

    背景 今天\(loj\)挂了,于是就有了闲情雅致来刷\(luogu\) 题面 洛谷P3387 [模板]缩点传送门 题意 给定一个\(n\)个点\(m\)条边有向图,每个点有一个权值,求一条路径,使路径 ...

  3. 洛谷 P3387 【模板】缩点 DAGdp学习记

    我们以洛谷P3387 [模板]缩点 来学习DAGdp 1.这道题的流程 //伪代码 for i->n if(i未被遍历) tarjan(i) 缩点() DAGdp() 完成 首先tarjan这部 ...

  4. tarjan缩点练习 洛谷P3387 【模板】缩点+poj 2186 Popular Cows

    缩点练习 洛谷 P3387 [模板]缩点 缩点 解题思路: 都说是模板了...先缩点把有环图转换成DAG 然后拓扑排序即可 #include <bits/stdc++.h> using n ...

  5. 洛谷——P3387 【模板】缩点

    P3387 [模板]缩点 题目背景 缩点+DP 题目描述 给定一个n个点m条边有向图,每个点有一个权值,求一条路径,使路径经过的点权值之和最大.你只需要求出这个权值和. 允许多次经过一条边或者一个点, ...

  6. 【模板】缩点(Tarjan算法)/洛谷P3387

    题目链接 https://www.luogu.com.cn/problem/P3387 题目大意 给定一个 \(n\) 个点 \(m\) 条边有向图,每个点有一个权值,求一条路径,使路径经过的点权值之 ...

  7. 洛谷P3387 【模板】缩点

    题目背景 缩点+DP 题目描述 给定一个n个点m条边有向图,每个点有一个权值,求一条路径,使路径经过的点权值之和最大.你只需要求出这个权值和. 允许多次经过一条边或者一个点,但是,重复经过的点,权值只 ...

  8. 洛谷 P3387 【模板】缩点

    题目背景 缩点+DP 题目描述 给定一个n个点m条边有向图,每个点有一个权值,求一条路径,使路径经过的点权值之和最大.你只需要求出这个权值和. 允许多次经过一条边或者一个点,但是,重复经过的点,权值只 ...

  9. 洛谷 P3387 题解

    题面 裸跑一遍SPFA,统计每个点的入队次数: 如果该点的入队次数>=总点数,那么该点便是一个负环上的点: 重点!!!: 1.不是“YES”,是“YE5”: 2.不是“NO”,是“N0”:(是零 ...

随机推荐

  1. 响应式开发(三)-----Bootstrap框架的安装使用

    下载 Bootstrap 可以从http://getbootstrap.com/上下载 Bootstrap 的最新版本. Download Bootstrap:下载 Bootstrap.点击该按钮,您 ...

  2. 安装JDK、Tomcat、Maven’详细步骤

    安装JDK 1.首先在官网下载JDK1.8包并解压(随便你装哪个版本) 2.下面开始配置环境变量  此电脑-右键-属性-高级系统配置  点击环境变量 将会看到以下界面 在系统变量下“新建” 变量名(J ...

  3. Service Fabric基本概念:Partition/Replicas示例

    作者:张鼎松 (Dingsong Zhang) @ Microsoft 在上一节的结尾简单介绍了Service Fabric中分区Partitions和复制replicas的概念,本节主要以示例的形式 ...

  4. P1978 集合

    P1978 集合 题目描述 集合是数学中的一个概念,用通俗的话来讲就是:一大堆数在一起就构成了集合.集合有如 下的特性: •无序性:任一个集合中,每个元素的地位都是相同的,元素之间是无序的. •互异性 ...

  5. day1 java基础语法

    一.关键字:java关键字有:abstract boolean break byte case catch char class const continue default do double el ...

  6. Java HashMap源码分析

    貌似HashMap跟ConcurrentHashMap是面试经常考的东西,抽空来简单分析下它的源码 构造函数 /** * Constructs an empty <tt>HashMap&l ...

  7. 利用XMLHttpRequest(XHR)对象实现与web服务器通信

    XMLHttpRequest对象:XMLHttpRequest是一个JS对象,页面利用它与web服务器通信.XHR对象的基本思想是让JS代码自己发送请求,以便随时获取数据,这种请求是异步的,也就是说请 ...

  8. soj1047.Super Snooker(转换思路+二路求和)

    Description On one of my many interplanetary travels I landed on a beautiful little planet called Cr ...

  9. 微服务深入浅出(5)-- 声明式调用Feign

    Feign的使用 Feign采用了声明式的API接口的风格,将Java Http客户端绑定到它的内部,从而调用过程变的简单. 配置文件: spring: application: name: eure ...

  10. JavaScript逻辑运算符

               逻辑运算符   或与非:&&  ||  ! ----------------------------------------------------------- ...