洛谷——P3387 【模板】缩点
P3387 【模板】缩点
题目背景
缩点+DP
题目描述
给定一个n个点m条边有向图,每个点有一个权值,求一条路径,使路径经过的点权值之和最大。你只需要求出这个权值和。
允许多次经过一条边或者一个点,但是,重复经过的点,权值只计算一次。
输入输出格式
输入格式:
第一行,n,m
第二行,n个整数,依次代表点权
第三至m+2行,每行两个整数u,v,表示u->v有一条有向边
输出格式:
共一行,最大的点权之和。
输入输出样例
说明
n<=10^4,m<=10^5,|点权|<=1000 算法:Tarjan缩点+DAGdp
啊啊啊啊啊,zz啊,把一个j写成了i,然后调了一晚上、、、
tarjan缩点+spfa求最长路
- #include<queue>
- #include<cstdio>
- #include<cstring>
- #include<iostream>
- #include<algorithm>
- #define N 100010
- using namespace std;
- queue<int>q;
- bool vis[N];
- int n,m,x,y,tot,tim,top,sum,ans,a[N],v[N],s[N];
- int dis[N],dfn[N],low[N],head[N],head1[N],stack[N],belong[N];
- int read()
- {
- ,f=; char ch=getchar();
- ;ch=getchar();}
- +ch-',ch=getchar();
- return x*f;
- }
- struct Edge
- {
- int to,next,from;
- }edge[N],edge1[N];
- int add(int x,int y)
- {
- tot++;
- edge[tot].to=y;
- edge[tot].next=head[x];
- head[x]=tot;
- }
- int add1(int x,int y)
- {
- tot++;
- edge1[tot].to=y;
- edge1[tot].next=head1[x];
- head1[x]=tot;
- }
- int spfa(int s)
- {
- ;i<=n;i++) dis[i]=-,vis[i]=false;
- dis[s]=v[s],vis[s]=true;
- q.push(s),ans=max(ans,v[s]);
- while(!q.empty())
- {
- x=q.front(); q.pop(),vis[x]=false;
- for(int i=head1[x];i;i=edge1[i].next)
- {
- int t=edge1[i].to;
- if(dis[t]>dis[x]+v[t]) continue;
- dis[t]=dis[x]+v[t];
- ans=max(ans,dis[t]);
- if(vis[t]) continue;
- vis[t]=true,q.push(t);
- }
- }
- }
- int tarjan(int x)
- {
- dfn[x]=low[x]=++tim;
- stack[++top]=x,vis[x]=true;
- for(int i=head[x];i;i=edge[i].next)
- {
- int t=edge[i].to;
- if(vis[t]) low[x]=min(low[x],dfn[t]);
- else if(!dfn[t]) tarjan(t),low[x]=min(low[x],low[t]);
- }
- if(low[x]==dfn[x])
- {
- sum++;belong[x]=sum;v[sum]+=a[x];
- for(;stack[top]!=x;top--)
- {
- v[sum]+=a[stack[top]];
- belong[stack[top]]=sum;
- vis[stack[top]]=false;
- }
- vis[x]=false,top--;
- }
- }
- int shink_point()
- {
- tot=;int t;
- ;i<=n;i++)
- for(int j=head[i];j;j=edge[j].next)
- {
- t=edge[j].to;
- if(belong[i]!=belong[t])
- add1(belong[i],belong[t]);
- }
- }
- int main()
- {
- n=read(),m=read();
- ;i<=n;i++) a[i]=read();
- ;i<=m;i++)
- x=read(),y=read(),add(x,y);
- ;i<=n;i++)
- if(!dfn[i]) tarjan(i);
- shink_point();
- ;i<=sum;i++)
- spfa(i);
- printf("%d",ans);
- }
洛谷——P3387 【模板】缩点的更多相关文章
- 洛谷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 ...
- 洛谷P3373 [模板]线段树 2(区间增减.乘 区间求和)
To 洛谷.3373 [模板]线段树2 题目描述 如题,已知一个数列,你需要进行下面两种操作: 1.将某区间每一个数加上x 2.将某区间每一个数乘上x 3.求出某区间每一个数的和 输入输出格式 输入格 ...
- 洛谷P3375 [模板]KMP字符串匹配
To 洛谷.3375 KMP字符串匹配 题目描述 如题,给出两个字符串s1和s2,其中s2为s1的子串,求出s2在s1中所有出现的位置. 为了减少骗分的情况,接下来还要输出子串的前缀数组next.如果 ...
- LCT总结——概念篇+洛谷P3690[模板]Link Cut Tree(动态树)(LCT,Splay)
为了优化体验(其实是强迫症),蒟蒻把总结拆成了两篇,方便不同学习阶段的Dalao们切换. LCT总结--应用篇戳这里 概念.性质简述 首先介绍一下链剖分的概念(感谢laofu的讲课) 链剖分,是指一类 ...
- 洛谷 P2656 (缩点 + DAG图上DP)
### 洛谷 P2656 题目链接 ### 题目大意: 小胖和ZYR要去ESQMS森林采蘑菇. ESQMS森林间有N个小树丛,M条小径,每条小径都是单向的,连接两个小树丛,上面都有一定数量的蘑菇.小胖 ...
- 【AC自动机】洛谷三道模板题
[题目链接] https://www.luogu.org/problem/P3808 [题意] 给定n个模式串和1个文本串,求有多少个模式串在文本串里出现过. [题解] 不再介绍基础知识了,就是裸的模 ...
- 洛谷-P5357-【模板】AC自动机(二次加强版)
题目传送门 -------------------------------------- 过年在家无聊补一下这周做的几道AC自动机的模板题 sol:AC自动机,还是要解决跳fail边产生的重复访问,但 ...
- 洛谷.1919.[模板]A*B Problem升级版(FFT)
题目链接:洛谷.BZOJ2179 //将乘数拆成 a0*10^n + a1*10^(n-1) + ... + a_n-1的形式 //可以发现多项式乘法就模拟了竖式乘法 所以用FFT即可 注意处理进位 ...
随机推荐
- Linux命令之---touch
命令简介 linux的touch命令不常用,一般在使用make的时候可能会用到,用来修改文件时间戳,或者新建一个不存在的文件. 命令格式 touch [选项]... 文件... 命令参数 -a 或 ...
- mysql-copy to tmp table
今天数据后台数据反映有些迟缓后查看链接 processlist 发下好多 锁 和磁盘写入, 参考文章 : http://bbs.chinaunix.net/forum.php?mod=viewth ...
- Java面试——多线程面试题总结
)两者都在等待对方所持有但是双方都不释放的锁,这时便会一直阻塞形成死锁. //存放两个资源等待被使用 public class Resource { public static Object obj1 ...
- Analyze Program Runtime Stack
Introduce: Process Explorer is an advanced process management utility that picks up where Task Manag ...
- 如何使用PowerShell管理Windows服务
[TechTarget中国原创] 作为一名系统管理员,最常见的任务之一就是学会管理Windows服务,这是保证Windows服务器和客户端正常运行的重要内容. 许多操作系统和应用程序都依赖于这些服务. ...
- C#入门篇5-8:流程控制语句 break语句
#region break语句 public class Breakapp { public static void Fun1() { //计算1+2+…+100的求和程序,打印显示每次循环计算的结果 ...
- 【Clone Graph】cpp
题目: Clone an undirected graph. Each node in the graph contains a label and a list of its neighbors. ...
- 【Interleaving String】cpp
题目: Given s1, s2, s3, find whether s3 is formed by the interleaving of s1 and s2. For example,Given: ...
- 用Python 3写的一个Spider小爬虫(使用内置urllib模块and正则表达式)
用Python写了一个Spider小爬虫,爬一爬斗鱼“王者荣耀”在线直播的主播及人气
- Mac Xnip 截图软件快捷键设置
点击 Shortcut 后输入你需要的截图快捷键