P3387 【模板】缩点

题目背景

缩点+DP

题目描述

给定一个n个点m条边有向图,每个点有一个权值,求一条路径,使路径经过的点权值之和最大。你只需要求出这个权值和。

允许多次经过一条边或者一个点,但是,重复经过的点,权值只计算一次。

输入输出格式

输入格式:

第一行,n,m

第二行,n个整数,依次代表点权

第三至m+2行,每行两个整数u,v,表示u->v有一条有向边

输出格式:

共一行,最大的点权之和。

输入输出样例

输入样例#1: 复制

  1. 2 2
  2. 1 1
  3. 1 2
  4. 2 1
输出样例#1: 复制

  1. 2

说明

n<=10^4,m<=10^5,|点权|<=1000 算法:Tarjan缩点+DAGdp

啊啊啊啊啊,zz啊,把一个j写成了i,然后调了一晚上、、、

tarjan缩点+spfa求最长路

  1. #include<queue>
  2. #include<cstdio>
  3. #include<cstring>
  4. #include<iostream>
  5. #include<algorithm>
  6. #define N 100010
  7. using namespace std;
  8. queue<int>q;
  9. bool vis[N];
  10. int n,m,x,y,tot,tim,top,sum,ans,a[N],v[N],s[N];
  11. int dis[N],dfn[N],low[N],head[N],head1[N],stack[N],belong[N];
  12. int read()
  13. {
  14. ,f=; char ch=getchar();
  15. ;ch=getchar();}
  16. +ch-',ch=getchar();
  17. return x*f;
  18. }
  19. struct Edge
  20. {
  21. int to,next,from;
  22. }edge[N],edge1[N];
  23. int add(int x,int y)
  24. {
  25. tot++;
  26. edge[tot].to=y;
  27. edge[tot].next=head[x];
  28. head[x]=tot;
  29. }
  30. int add1(int x,int y)
  31. {
  32. tot++;
  33. edge1[tot].to=y;
  34. edge1[tot].next=head1[x];
  35. head1[x]=tot;
  36. }
  37. int spfa(int s)
  38. {
  39. ;i<=n;i++) dis[i]=-,vis[i]=false;
  40. dis[s]=v[s],vis[s]=true;
  41. q.push(s),ans=max(ans,v[s]);
  42. while(!q.empty())
  43. {
  44. x=q.front(); q.pop(),vis[x]=false;
  45. for(int i=head1[x];i;i=edge1[i].next)
  46. {
  47. int t=edge1[i].to;
  48. if(dis[t]>dis[x]+v[t]) continue;
  49. dis[t]=dis[x]+v[t];
  50. ans=max(ans,dis[t]);
  51. if(vis[t]) continue;
  52. vis[t]=true,q.push(t);
  53. }
  54. }
  55. }
  56. int tarjan(int x)
  57. {
  58. dfn[x]=low[x]=++tim;
  59. stack[++top]=x,vis[x]=true;
  60. for(int i=head[x];i;i=edge[i].next)
  61. {
  62. int t=edge[i].to;
  63. if(vis[t]) low[x]=min(low[x],dfn[t]);
  64. else if(!dfn[t]) tarjan(t),low[x]=min(low[x],low[t]);
  65. }
  66. if(low[x]==dfn[x])
  67. {
  68. sum++;belong[x]=sum;v[sum]+=a[x];
  69. for(;stack[top]!=x;top--)
  70. {
  71. v[sum]+=a[stack[top]];
  72. belong[stack[top]]=sum;
  73. vis[stack[top]]=false;
  74. }
  75. vis[x]=false,top--;
  76. }
  77. }
  78. int shink_point()
  79. {
  80. tot=;int t;
  81. ;i<=n;i++)
  82. for(int j=head[i];j;j=edge[j].next)
  83. {
  84. t=edge[j].to;
  85. if(belong[i]!=belong[t])
  86. add1(belong[i],belong[t]);
  87. }
  88. }
  89. int main()
  90. {
  91. n=read(),m=read();
  92. ;i<=n;i++) a[i]=read();
  93. ;i<=m;i++)
  94. x=read(),y=read(),add(x,y);
  95. ;i<=n;i++)
  96. if(!dfn[i]) tarjan(i);
  97. shink_point();
  98. ;i<=sum;i++)
  99. spfa(i);
  100. printf("%d",ans);
  101. }

洛谷——P3387 【模板】缩点的更多相关文章

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

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

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

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

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

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

  4. 洛谷P3373 [模板]线段树 2(区间增减.乘 区间求和)

    To 洛谷.3373 [模板]线段树2 题目描述 如题,已知一个数列,你需要进行下面两种操作: 1.将某区间每一个数加上x 2.将某区间每一个数乘上x 3.求出某区间每一个数的和 输入输出格式 输入格 ...

  5. 洛谷P3375 [模板]KMP字符串匹配

    To 洛谷.3375 KMP字符串匹配 题目描述 如题,给出两个字符串s1和s2,其中s2为s1的子串,求出s2在s1中所有出现的位置. 为了减少骗分的情况,接下来还要输出子串的前缀数组next.如果 ...

  6. LCT总结——概念篇+洛谷P3690[模板]Link Cut Tree(动态树)(LCT,Splay)

    为了优化体验(其实是强迫症),蒟蒻把总结拆成了两篇,方便不同学习阶段的Dalao们切换. LCT总结--应用篇戳这里 概念.性质简述 首先介绍一下链剖分的概念(感谢laofu的讲课) 链剖分,是指一类 ...

  7. 洛谷 P2656 (缩点 + DAG图上DP)

    ### 洛谷 P2656 题目链接 ### 题目大意: 小胖和ZYR要去ESQMS森林采蘑菇. ESQMS森林间有N个小树丛,M条小径,每条小径都是单向的,连接两个小树丛,上面都有一定数量的蘑菇.小胖 ...

  8. 【AC自动机】洛谷三道模板题

    [题目链接] https://www.luogu.org/problem/P3808 [题意] 给定n个模式串和1个文本串,求有多少个模式串在文本串里出现过. [题解] 不再介绍基础知识了,就是裸的模 ...

  9. 洛谷-P5357-【模板】AC自动机(二次加强版)

    题目传送门 -------------------------------------- 过年在家无聊补一下这周做的几道AC自动机的模板题 sol:AC自动机,还是要解决跳fail边产生的重复访问,但 ...

  10. 洛谷.1919.[模板]A*B Problem升级版(FFT)

    题目链接:洛谷.BZOJ2179 //将乘数拆成 a0*10^n + a1*10^(n-1) + ... + a_n-1的形式 //可以发现多项式乘法就模拟了竖式乘法 所以用FFT即可 注意处理进位 ...

随机推荐

  1. Linux命令之---touch

    命令简介 linux的touch命令不常用,一般在使用make的时候可能会用到,用来修改文件时间戳,或者新建一个不存在的文件. 命令格式 touch [选项]... 文件... 命令参数 -a   或 ...

  2. mysql-copy to tmp table

    今天数据后台数据反映有些迟缓后查看链接 processlist 发下好多 锁 和磁盘写入,   参考文章 : http://bbs.chinaunix.net/forum.php?mod=viewth ...

  3. Java面试——多线程面试题总结

    )两者都在等待对方所持有但是双方都不释放的锁,这时便会一直阻塞形成死锁. //存放两个资源等待被使用 public class Resource { public static Object obj1 ...

  4. Analyze Program Runtime Stack

    Introduce: Process Explorer is an advanced process management utility that picks up where Task Manag ...

  5. 如何使用PowerShell管理Windows服务

    [TechTarget中国原创] 作为一名系统管理员,最常见的任务之一就是学会管理Windows服务,这是保证Windows服务器和客户端正常运行的重要内容. 许多操作系统和应用程序都依赖于这些服务. ...

  6. C#入门篇5-8:流程控制语句 break语句

    #region break语句 public class Breakapp { public static void Fun1() { //计算1+2+…+100的求和程序,打印显示每次循环计算的结果 ...

  7. 【Clone Graph】cpp

    题目: Clone an undirected graph. Each node in the graph contains a label and a list of its neighbors. ...

  8. 【Interleaving String】cpp

    题目: Given s1, s2, s3, find whether s3 is formed by the interleaving of s1 and s2. For example,Given: ...

  9. 用Python 3写的一个Spider小爬虫(使用内置urllib模块and正则表达式)

    用Python写了一个Spider小爬虫,爬一爬斗鱼“王者荣耀”在线直播的主播及人气

  10. Mac Xnip 截图软件快捷键设置

    点击 Shortcut 后输入你需要的截图快捷键