题目链接

题意分析

我们仔细分析一下 发现题目要求用最多\(k\)条路径实现最小权覆盖

首先由于最小路径覆盖针对的是有向图 但是这是一个无向图

所以我们面向对象编程

我们维护一个数组\(d[i][j]\) 表示\(i,j\)之间的最短距离

由于是\(n≤150\) 所以我们可以使用\(floyed\)求

同时由于我们用\(k\)更新\(i,j\)的话 必须是满足 \(k\)小于等于\(max(i,j)\)

因为我们假设已经炸毁了\(u\)

然后去摧毁\(v\) 那么如果我们经过了\(max(u,v)\) 那么\(v\)肯定已经摧毁了

那么再摧毁就没有意义了

然后维护成了一个\(DAG\)

然后我们在\(DAG\)上跑最多\(k\)条最小路径覆盖

我们对于每一个点拆成两个点\(a,b\)

然后源点向\(0_a\)连一条容量为\(k\) 费用为\(0\)的边

源点向\((1-n)_a\)连一条容量为\(1\)费用为\(0\)的边

同时\((0-n)_b\)分别向汇点连一条容量为\(1\)费用为\(0\)的边

然后对于一条边\((x,y)\)(这里强制\(x<y\))

我们由\(x_a\)向\(y_b\)连一条容量为\(1\)费用为\(dis[x][y]\)的边

然后跑最小费用最大流即可


\(DAG\)上的最小不相交路径覆盖问题

我们对于每一个点拆成两个点

然后按照连接关系由于左边的点向右边的点连边

然后\(ans\)=原图顶点数-最大匹配数

\(DAG\)上的最小可相交路径覆盖问题

我们跑一遍\(floyed\)传递闭包

然后做法同上


CODE:

  1. #include<iostream>
  2. #include<cstdio>
  3. #include<cstring>
  4. #include<cmath>
  5. #include<algorithm>
  6. #include<cstdlib>
  7. #include<string>
  8. #include<queue>
  9. #include<map>
  10. #include<stack>
  11. #include<list>
  12. #include<set>
  13. #include<deque>
  14. #include<vector>
  15. #include<ctime>
  16. #define ll long long
  17. #define inf 0x7fffffff
  18. #define N 208
  19. #define IL inline
  20. #define M 1008611
  21. #define D double
  22. #define ull unsigned long long
  23. #define R register
  24. using namespace std;
  25. template<typename T>IL void read(T &_)
  26. {
  27. T __=0,___=1;char ____=getchar();
  28. while(!isdigit(____)) {if(____=='-') ___=0;____=getchar();}
  29. while(isdigit(____)) {__=(__<<1)+(__<<3)+____-'0';____=getchar();}
  30. _=___ ? __:-__;
  31. }
  32. /*-------------OI使我快乐-------------*/
  33. int n,m,k,tot=1,S,T,have;ll ans;
  34. int dis[N][N];
  35. int to[M],nex[M],head[N<<1],w[M],cost[M];
  36. int dep[N<<1],flow[N<<1],pre[N<<1],las[N<<1];
  37. bool vis[N<<1];queue<int> Q;
  38. IL void add(int x,int y,int z,int f)
  39. {to[++tot]=y;nex[tot]=head[x];head[x]=tot;w[tot]=z;cost[tot]=f;
  40. swap(x,y);to[++tot]=y;nex[tot]=head[x];head[x]=tot;w[tot]=0;cost[tot]=-f;}
  41. IL bool spfa()
  42. {
  43. memset(dep,0x3f,sizeof dep);
  44. memset(flow,0x3f,sizeof flow);
  45. memset(vis,0,sizeof vis);
  46. dep[S]=0;vis[S]=1;Q.push(S);pre[T]=-1;
  47. while(!Q.empty())
  48. {
  49. int u=Q.front();Q.pop();vis[u]=0;
  50. for(R int i=head[u];i;i=nex[i])
  51. {
  52. int v=to[i];
  53. if(w[i]>0&&dep[v]>dep[u]+cost[i])
  54. {
  55. dep[v]=dep[u]+cost[i];
  56. flow[v]=min(flow[u],w[i]);
  57. pre[v]=u;las[v]=i;
  58. if(!vis[v]) {vis[v]=1;Q.push(v);}
  59. }
  60. }
  61. }
  62. return pre[T]!=-1;
  63. }
  64. IL void EK()
  65. {
  66. while(spfa())
  67. {
  68. have+=flow[T];
  69. ans+=1ll*flow[T]*dep[T];
  70. for(R int now=T;now!=S;now=pre[now])
  71. {
  72. w[las[now]]-=flow[T];w[las[now]^1]+=flow[T];
  73. }
  74. }
  75. }
  76. int main()
  77. {
  78. // freopen(".in","r",stdin);
  79. // freopen(".out","w",stdout);
  80. read(n);read(m);read(k);++n;S=(n<<1)+1;T=(n<<1)+2;
  81. for(R int i=1;i<=n;++i) dis[i][i]=0;
  82. memset(dis,0x3f,sizeof dis);
  83. for(R int i=1,x,y,z;i<=m;++i)
  84. {
  85. read(x);read(y);read(z);++x;++y;
  86. dis[x][y]=dis[y][x]=min(dis[x][y],z);
  87. }
  88. for(R int p=1;p<=n;++p)
  89. for(R int i=1;i<=n;++i)
  90. for(R int j=1;j<=n;++j)
  91. if(p<=max(i,j))
  92. dis[i][j]=min(dis[i][j],dis[i][p]+dis[p][j]);
  93. // for(R int i=1;i<=n;++i)
  94. // for(R int j=1;j<=n;++j)
  95. // printf("%d%c",dis[i][j],(j==n ? '\n':' '));
  96. for(R int i=1;i<=n;++i)
  97. for(R int j=i+1;j<=n;++j)
  98. add(i,j+n,1,dis[i][j]);
  99. add(S,1,k,0);for(R int i=2;i<=n;++i) add(S,i,1,0);
  100. for(R int i=1;i<=n;++i) add(i+n,T,1,0);
  101. EK();
  102. printf("%lld\n",ans);
  103. // fclose(stdin);
  104. // fclose(stdout);
  105. return 0;
  106. }

HEOI 2019 RP++

P4542 [ZJOI2011]营救皮卡丘的更多相关文章

  1. P4542 [ZJOI2011]营救皮卡丘(Floyd+网络流)

    P4542 [ZJOI2011]营救皮卡丘 乍一看似乎没啥题相似的 仔细一看,$N<=150$ 边又是双向边,似乎可以用Floyd搞   先跑一遍Floyd处理出$dis[i][j]$ 注意到走 ...

  2. 洛咕P4542 [ZJOI2011]营救皮卡丘

    套路题? 感觉讲不清,先写建图 把每个点拆成两个,A和B, S->Ai流量=1费用=0,Bi->T流量=1费用=0, Ai->Bj流量=1费用=ij最短路 还有一个特殊的s点,S-& ...

  3. bzoj 2324 [ZJOI2011]营救皮卡丘(floyd,费用流)

    2324: [ZJOI2011]营救皮卡丘 Time Limit: 10 Sec  Memory Limit: 256 MBSubmit: 1777  Solved: 712[Submit][Stat ...

  4. BZOJ2324: [ZJOI2011]营救皮卡丘

    2324: [ZJOI2011]营救皮卡丘 Time Limit: 10 Sec  Memory Limit: 256 MBSubmit: 1359  Solved: 522[Submit][Stat ...

  5. BZOJ 2324: [ZJOI2011]营救皮卡丘( floyd + 费用流 )

    昨晚写的题...补发一下题解... 把1~N每个点拆成xi, yi 2个. 预处理i->j经过编号不超过max(i,j)的最短路(floyd) S->0(K, 0), S->xi(1 ...

  6. 【BZOJ2324】[ZJOI2011]营救皮卡丘(网络流,费用流)

    [BZOJ2324][ZJOI2011]营救皮卡丘(网络流,费用流) 题面 BZOJ 洛谷 题解 如果考虑每个人走的路径,就会很麻烦. 转过来考虑每个人破坏的点集,这样子每个人可以得到一个上升的序列. ...

  7. 【BZOJ2324】[ZJOI2011]营救皮卡丘 有上下界费用流

    [BZOJ2324][ZJOI2011]营救皮卡丘 Description 皮卡丘被火箭队用邪恶的计谋抢走了!这三个坏家伙还给小智留下了赤果果的挑衅!为了皮卡丘,也为了正义,小智和他的朋友们义不容辞的 ...

  8. bzoj2324 [ZJOI2011]营救皮卡丘 费用流

    [ZJOI2011]营救皮卡丘 Time Limit: 10 Sec  Memory Limit: 256 MBSubmit: 2653  Solved: 1101[Submit][Status][D ...

  9. 【BZOJ 2324】 [ZJOI2011]营救皮卡丘

    Description 皮卡丘被火箭队用邪恶的计谋抢走了!这三个坏家伙还给小智留下了赤果果的挑衅!为了皮卡丘,也为了正义,小智和他的朋友们义不容辞的踏上了营救皮卡丘的道路. 火箭队一共有N个据点,据点 ...

随机推荐

  1. ssh 连接很慢的解决办法

    http://blog.csdn.net/ablo_zhou/article/details/5074887 ============= 现象: 在局域网内,能ping通目标机器,并且时延是微秒级. ...

  2. nvidia显卡驱动

    http://blog.csdn.net/Monica__2012/article/details/75577522 $nvidia-smi

  3. 13 Calculating Expected Offspring

    Problem For a random variable XX taking integer values between 1 and nn, the expected value of XX is ...

  4. tp5主从数据库设置读写分离

    // 数据库类型 'type' => 'mysql', // 服务器地址 'hostname' => '192.168.0.5,192.168.0.6', // 数据库名 'databas ...

  5. mysql event 入门

    delimiter | CREATE EVENT statistics_event ON SCHEDULE EVERY DAY STARTS CONCAT(CURRENT_DATE(), ' 00:0 ...

  6. c++ vector反转reverse

    template <class BidirectionalIterator> void reverse ( BidirectionalIterator first, Bidirection ...

  7. Oracle EBS View 视图查看没有数据

    --关于看视图查看没有数据的问题 --原因OU过滤关系 --Oracle SQL*Plus --toad EXECUTE  fnd_client_info.set_org_context(:ou_id ...

  8. 咏南树形下拉列表数据敏感控件--TYNdbTreeList

    咏南树形下拉列表数据敏感控件--TYNdbTreeList 软件系统拥有自己通用的下拉列表控件可以大大地加速系统的开发和易用性. 控件支持DELPHI5及以上版本安装并使用. 控件的用法: proce ...

  9. delphi http 403 获取不到服务器返回的错误消息 用浏览器打开url可以返回

    用delphi的idhttp Get一个url如下: http://117.135.237.4:9090/agent/api/treatmentModeUpdate?userName=VDAwMIMQ ...

  10. Android-工作总结-LX-2018-08-20-判断数据库表字段是否为空

    问题的因素: 调试了一上午,我要判断数据库表的name字段是否为空,使用了TextUtils.isEmpty(nameStr):来判断name字段是否为空,明明数据库是没有值,却一直显示有值,然后还去 ...