Description

在艾泽拉斯的无尽之海里,有着一群不为人知的由各个种族的冒险者统治的岛屿,这些岛屿都很庞大,足以在上面建造许多的城市,城市之间有一些单向道路连接。
有一天,QYQ无意中发现了这些岛屿,并且发现在每个城市的地下都或多或少埋藏着一些装备、金币、宝物……
可是正当QYQ兴奋不已打算全部把它们拿走时,他却惊奇的发现你的魔法在这里被限制住了,唯一可用的技能就是闪现,而且魔法只够他使用K次这个技能了,每次使用这个技能QYQ只能从一个岛屿上闪现到另外一个岛屿上。每一个岛屿只能登上一次,QYQ可以从任何一个城市开始旅程,在任何一个城市结束旅程。
城市的数量共有n个,有m条道路,每一条道路有两个参数u,v,表示从u到v有一条道路,但你只能由u到v走,两个城市属于相同的岛屿当且仅当暂时将所有道路视为双向道路时可以从其中一个城市走到另一个城市(可以途径其它城市)。
每一个城市都有一个宝物的总价值v[i],你的任务是帮助QYQ得到最大总价值的宝物,并输出这个值。

Input

从文件azeroth.in中输入数据。
输入的第一行包含两个整数n,m
输入的第二行到第m+1行,每行包含2个整数u,v,代表你可以从城市u走到城市v
输入的第m+2行包含n个整数,第i个整数代表v[i],即这个城市的宝物总价值。
输入的第m+3行包含一个整数K,代表你可以使用技能的次数。

Output

输出到文件azeroth.out中。
输出的第一行包含一个整数,代表QYQ能获得的最大的宝物总价值

Sample Input

3 21 23 11 2 10

Sample Output

4样例说明:QYQ从3号点开始,走到2号点,最后走到1号点,结束旅程,共获得1+2+1=4价值的宝物

Data Constraint

对于30%的数据:n<=10,K=0
对于50%的数据:n<=100,m<=100,K<=1
对于100%的数据:1<=n<=100000,1<=m<=1000000,1<=v[i]<=1000,0<=K<=100000
图中可能会有重边、自环。

题解

  • 题目大意:给定一个有向有环图,每个环只能走一次,有k次在任意环上跳的次数,问可以得到的最大价值
  • 这种题,先来个Tarjan缩点,然后就变成了有向无环图,就是一个DAG
  • 然后我们只用处理每个环,也就是每个有向的连通块,进行dp,设f[i]为从第i个连通块开始能获得的最大价值
  • 那么一个有向的连通块的最大价值,就是所有在这个连通块中的所有点能获得的最大价值
  • 最后答案就是所有连通块价值的前k个之和

代码

 1 #include <cstdio>
 2 #include <iostream>
 3 #include <cstring>
 4 #include <algorithm>
 5 using namespace std;
 6 const int N=1e5+10,M=1e6+10;
 7 int n,m,num,tot,K,Ans,cnt[2],sum[N],head[2][N],f[N],a[N],Num[N],bel[N],ans[N],fa[N],dfn[N],low[N],p[N];
 8 bool b[N],vis[N];
 9 struct edge { int x,y; }e[2][M];
10 void insert(int p,int x,int y) { e[p][++cnt[p]].x=y,e[p][cnt[p]].y=head[p][x],head[p][x]=cnt[p]; }
11 int getfather(int x) { return fa[x]==x?x:fa[x]=getfather(fa[x]); }
12 void Tarjan(int x)
13 {
14     dfn[x]=low[x]=++dfn[0],p[++tot]=x,vis[x]=1;
15     for (int i=head[0][x];i;i=e[0][i].y)
16         if (!bel[e[0][i].x])
17         {
18             if (vis[e[0][i].x]) low[x]=min(low[x],dfn[e[0][i].x]);
19             else Tarjan(e[0][i].x),low[x]=min(low[x],low[e[0][i].x]);
20         }
21     if (dfn[x]==low[x])
22     {
23         num++; int v;
24         do
25         {
26             v=p[tot--],bel[v]=num,sum[num]+=a[v],vis[v]=0;
27         }while(v!=x);
28     }
29 }
30 void work(int x)
31 {
32     b[x]=1,f[x]+=sum[x];
33     for (int i=head[1][x];i;i=e[1][i].y)
34     {
35         getfather(x),getfather(e[1][i].x);
36         fa[fa[x]]=fa[e[1][i].x],Num[e[1][i].x]--,f[e[1][i].x]=max(f[x],f[e[1][i].x]);
37         if (!Num[e[1][i].x]) work(e[1][i].x);
38     }
39 }
40 int main()
41 {
42     freopen("azeroth.in","r",stdin),freopen("azeroth.out","w",stdout),scanf("%d%d",&n,&m);
43     for (int i=1,x,y;i<=m;i++) { scanf("%d%d",&x,&y); if (x==y) continue; insert(0,x,y); }
44     for (int i=1;i<=n;i++) scanf("%d",&a[i]);
45     scanf("%d",&K);
46     for (int i=1;i<=n;i++) if (!bel[i]) Tarjan(i);
47     for (int i=1;i<=n;i++)
48         for (int j=head[0][i];j;j=e[0][j].y)
49             if (bel[i]!=bel[e[0][j].x])
50                 insert(1,bel[i],bel[e[0][j].x]),Num[bel[e[0][j].x]]++;
51     for (int i=1;i<=num;i++) fa[i]=i;
52     for (int i=1;i<=num;i++) if (!Num[i]&!b[i]) work(i);
53     for (int i=1;i<=num;i++) getfather(i),ans[fa[i]]=max(ans[fa[i]],f[i]);
54     sort(ans+1,ans+num+1);
55     for (int i=num;i>=max(1,num-K);i--) Ans+=ans[i];
56     printf("%d",Ans);
57 }

转载于:https://www.cnblogs.com/Comfortable/p/10339464.html

[Tarjan][并查集][dp] Jzoj P4253 QYQ在艾泽拉斯相关推荐

  1. Jzoj P4253 QYQ在艾泽拉斯___强连通分量缩点+拓扑序dp

    题目大意: Q Y Q QYQ QYQ有 K K K次技能,每次可以从一个岛屿上闪现到另外一个岛屿上,每一个岛屿只能登上一次. Q Y Q QYQ QYQ能从任何一个城市开始旅程,也能在任何一个城市结 ...

  2. POJ 1417 True Liars(路径压缩并查集+DP背包问题)

    POJ 1417 True Liars(路径压缩并查集+DP背包问题) http://poj.org/problem?id=1417 题意: 给出p1+p2个人,其中p1个是好人,p2个是坏人.然后有 ...

  3. [拓扑排序][DP][Tarjan][并查集]JZOJ 4253 QYQ在艾泽拉斯

    Description 在艾泽拉斯的无尽之海里,有着一群不为人知的由各个种族的冒险者统治的岛屿,这些岛屿都很庞大,足以在上面建造许多的城市,城市之间有一些单向道路连接. 有一天,QYQ无意中发现了这些 ...

  4. poj 3728 The merchant// lca(倍增实现) + dp || tarjan+并查集路径上dp

    poj 3728 The merchant// lca(倍增实现) + dp Time Limit: 3000MS   Memory Limit: 65536K Total Submissions: ...

  5. 【并查集+dp】Team

    Team 时间限制: 1 Sec  内存限制: 128 MB 提交: 124  解决: 10 [提交] [状态] [命题人:admin] 题目描述 ACM-ICPC is a interesting ...

  6. 洛谷·[POI2005]SKA-Piggy Banks 小猪存钱罐【Tarjan 并查集

    初见安~这里是传送门:洛谷P3420 题目描述3 Byteazar the Dragon has NN piggy banks. Each piggy bank can either be opene ...

  7. [并查集][排序] Jzoj P4223 旅游

    Description Input Output Sample Input 15 5 32 3 63341 5 157243 5 57054 3 123821 3 217266000100001300 ...

  8. P1455-搭配购买【图论,并查集,dp,背包】

    正题 题目链接: https://www.luogu.org/problemnew/show/P1455 大意 有n个商品,给出价值和价格.有m组搭配,如果买了其中一个就得买另一个,给出你拥有的钱,求 ...

  9. [HDOJ2586]How far away?(最近公共祖先, 离线tarjan, 并查集)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2586 这题以前做过-现在用tarjan搞一发-竟然比以前暴力过的慢---- 由于是离线算法,需要Que ...

最新文章

  1. Invalid input for operation: physical_network 'physnet1' unknown for flat provider network.
  2. 如何让Window对话窗口重新获得输入焦点
  3. github入门必备概念
  4. Linux 系统目录结构
  5. 第一次认识SharePoint...
  6. 经典C语言程序100例之六一
  7. 大数据告诉你,电商都把假货发给谁?
  8. 实验4-1-10 兔子繁衍问题 (15 分)
  9. 【概率证明】—— sum and product rules of probability
  10. 关于使用UIWebView加载HTTPS站点
  11. 【C语言】新手入门的C语言经典实例(持续更新)
  12. 企业架构皇冠上的明珠:TOGAF
  13. JavaScript计算器
  14. 紫阳的日常——第一章 拒绝访问的高考成绩
  15. C语言学习日记(2)——写个Hello,World测试一下
  16. Golang IDE总汇
  17. oracle 朱志辉_甲骨文(Oracle)授权教育中心落户我校
  18. 7月Python最佳开源项目Top 10
  19. Developer Cloud -帮助和支持
  20. golang 简明教程

热门文章

  1. 使用Cypress自动化框架进行Web/API测试
  2. Curator之Recipes之选举
  3. FreeRADIUS RADMIN说明
  4. Linux系统编程【5】——stty的学习
  5. 消息队列模式(点对点发布订阅)
  6. js轮播图(手动轮播+自动轮播)
  7. 教你如何更改wifi密码以及防蹭网
  8. 传统神经网络ANN训练算法总结
  9. 如何在淘宝普通店铺宝贝描述里添加背景图片添加 - 生活至上,美容至尚!
  10. Windows Live Mail的设置方法