Background

在一个遥远的世界里有两个国家:位于大陆西端的杰森国和位于大陆东端的克里斯国。两个国家的人民分别信仰两个对立的神:杰森国信仰象征黑暗和毁灭的神曾·布拉泽,而克里斯国信仰象征光明和永恒的神斯普林·布拉泽。

幻想历8012年1月,杰森国正式宣布曾·布拉泽是他们唯一信仰的神,同时开始迫害在杰森国的信仰斯普林·布拉泽的克里斯国教徒。

幻想历8012年3月2日,位于杰森国东部小镇神谕镇的克里斯国教徒发动起义。

幻想历8012年3月7日,神谕镇的起义被杰森国大军以残酷手段镇压。

幻想历8012年3月8日,克里斯国对杰森国宣战。由数十万大军组成的克里斯军团开至两国边境,与杰森军团对峙。

幻想历8012年4月,克里斯军团攻破杰森军团防线进入神谕镇,该镇幸存的克里斯国教徒得到解放。

战争随后进入胶着状态,旷日持久。战况惨烈,一时间枪林弹雨,硝烟弥漫,民不聊生。

Description

幻想历8012年5月12日深夜,斯普林·布拉泽降下神谕:“Trust me, earn eternal life.”克里斯军团士气大增。作为克里斯军团的主帅,你决定利用这一机会发动奇袭,一举击败杰森国。具体地说,杰森国有N个城市,由M条单向道路连接。神谕镇是城市1而杰森国的首都是城市N。你只需摧毁位于杰森国首都的曾·布拉泽大神殿,杰森国的信仰,军队还有一切就都会土崩瓦解,灰飞烟灭。

为了尽量减小己方的消耗,你决定使用自爆机器人完成这一任务。唯一的困难是,杰森国的一部分城市有结界保护,不破坏掉结界就无法进入城市。而每个城市的结界都是由分布在其他城市中的一些结界发生器维持的,如果想进入某个城市,你就必须破坏掉维持这个城市结界的所有结界发生器。

现在你有无限多的自爆机器人,一旦进入了某个城市,自爆机器人可以瞬间引爆,破坏一个目标(结界发生器,或是杰森国大神殿),当然机器人本身也会一起被破坏。你需要知道:摧毁杰森国所需的最短时间。

Input

输入文件的landcraft.in的第一行两个正整数N, M。

接下来M行,每行三个正整数ui, vi, wi,表示有一条从城市ui到城市vi的单向道路,自爆机器人通过这条道路需要wi的时间。

之后N行,每行描述一个城市。首先是一个正整数li,维持这个城市结界所使用的结界发生器数目。之后li个1~N之间的城市编号,表示每个结界发生器的位置。如果li = 0,则说明该城市没有结界保护,保证l1 = 0 。

Output

输出文件landcraft.out仅包含一个正整数 ,击败杰森国所需的最短时间。

最短路问题,结果因为数组开小改了好久???

记录\(dis[x]\)代表到达\(x\)的最短时间。

记录\(real[x]\)代表到达\(x\)的实际时间。

对于每一个点,我们去更新其相连节点的时候要用\(max(dis[x],real[x])\)去更新。

然后注意建立结界保护的边的时候建\(li\)到\(i\)的有向边。

因为我搞不清所以直接建双向边

然后最后输出答案输出\(max(dis[n],real[n])\)即可。

代码

  1. #include<cstdio>
  2. #include<iostream>
  3. #include<algorithm>
  4. #include<queue>
  5. #define R register
  6. using namespace std;
  7. const int gz=5e4+8;
  8. inline void in(R int &x)
  9. {
  10. R int f=1;x=0;char s=getchar();
  11. while(!isdigit(s)){if(s=='-')f=-1;s=getchar();}
  12. while(isdigit(s)){x=x*10+s-'0';s=getchar();}
  13. x*=f;
  14. }
  15. int head[gz],tot,pr[gz],cnt,hd[gz];
  16. struct cod{int u,v,w;}edge[gz<<1],e[gz<<1];
  17. inline void add(R int x,R int y,R int z)
  18. {
  19. edge[++tot].u=head[x];
  20. edge[tot].v=y;
  21. edge[tot].w=z;
  22. head[x]=tot;
  23. }
  24. inline void ado(R int x,R int y)
  25. {
  26. e[++cnt].u=pr[x];
  27. e[cnt].v=y;
  28. pr[x]=cnt;
  29. }
  30. int dis[gz],real[gz],n,m;
  31. bool vis[gz];
  32. struct hop
  33. {
  34. int u,d;
  35. bool operator <(const hop&a)const
  36. {
  37. return d>a.d;
  38. };
  39. };
  40. inline void dij()
  41. {
  42. for(R int i=1;i<=n;i++)dis[i]=2147483644;
  43. priority_queue<hop>q;dis[1]=real[1]=0;
  44. q.push((hop){1,0});
  45. while(!q.empty())
  46. {
  47. R int u=q.top().u;q.pop();
  48. if(vis[u])continue;
  49. vis[u]=true;
  50. R int now=max(dis[u],real[u]);
  51. for(R int i=head[u];i;i=edge[i].u)
  52. {
  53. if(dis[edge[i].v]>now+edge[i].w)
  54. {
  55. dis[edge[i].v]=now+edge[i].w;
  56. if(hd[edge[i].v]==0)
  57. q.push((hop){edge[i].v,max(dis[edge[i].v],real[edge[i].v])});
  58. }
  59. }
  60. for(R int i=pr[u];i;i=e[i].u)
  61. {
  62. hd[e[i].v]--;
  63. real[e[i].v]=max(real[e[i].v],now);
  64. if(hd[e[i].v]==0)
  65. q.push((hop){e[i].v,max(real[e[i].v],dis[e[i].v])});
  66. }
  67. }
  68. printf("%d\n",max(real[n],dis[n]));
  69. }
  70. int main()
  71. {
  72. in(n),in(m);
  73. for(R int i=1,x,y,z;i<=m;i++)
  74. {
  75. in(x),in(y),in(z);
  76. if(x==y)continue;
  77. add(x,y,z);
  78. }
  79. for(R int i=1,x;i<=n;i++)
  80. {
  81. in(x);hd[i]=x;
  82. for(R int fk;x;x--)
  83. in(fk),ado(fk,i),ado(i,fk);
  84. }
  85. dij();
  86. }

Dijkstra【P2446】 [SDOI2010]大陆争霸的更多相关文章

  1. 洛谷 P2446 [SDOI2010]大陆争霸 解题报告

    P2446 [SDOI2010]大陆争霸 题目背景 在一个遥远的世界里有两个国家:位于大陆西端的杰森国和位于大陆东端的克里斯国.两个国家的人民分别信仰两个对立的神:杰森国信仰象征黑暗和毁灭的神曾·布拉 ...

  2. 洛谷——P2446 [SDOI2010]大陆争霸

    https://www.luogu.org/problem/show?pid=2446#sub 题目背景 在一个遥远的世界里有两个国家:位于大陆西端的杰森国和位于大陆东端的克里斯国.两个国家的人民分别 ...

  3. P2446 [SDOI2010]大陆争霸

    \(\color{#0066ff}{ 题目描述 }\) 幻想历8012年5月12日深夜,斯普林·布拉泽降下神谕:"Trust me, earn eternal life."克里斯军 ...

  4. AC日记——[SDOI2010]大陆争霸 洛谷 P3690

    [SDOI2010]大陆争霸 思路: dijkstra模板: 代码: #include <bits/stdc++.h> using namespace std; #define maxn ...

  5. bzoj1922 [SDOI2010]大陆争霸 分层图

    问题描述 幻想历8012年5月12日深夜,斯普林·布拉泽降下神谕:“Trust me, earn eternal life.”克里斯军团士气大增.作为克里斯军团的主帅,你决定利用这一机会发动奇袭,一举 ...

  6. 【bzoj1922】[Sdoi2010]大陆争霸 堆优化Dijkstra

    题目描述 一张n个点m条边的图,通过每条边需要一定的时间.有一些限制条件,每个限制条件形如“x保护y”,表示到达y的最短时间不能小于到达x的最短时间(即如果在其之前到达,则需要等待至xd到达).问1到 ...

  7. 【bzoj1922】[Sdoi2010]大陆争霸 - STL - dijkstra

    信仰斯普林·布拉泽的克里斯国教徒. 幻想历 8012年 3月2日,位于杰森国东部小镇神谕镇的克里斯国教徒发动 起义. 幻想历 8012年 3月7日,神谕镇的起义被杰森国大军以残酷手段镇压. 幻想历 8 ...

  8. BZOJ 1922: [Sdoi2010]大陆争霸 Dijkstra

    Code: #include <queue> #include <vector> #include <cstdio> #include <cstring> ...

  9. 【BZOJ1922】[Sdoi2010]大陆争霸 Dijkstra

    Description 具体地说,杰森国有 N 个城市,由 M条单向道 路连接.神谕镇是城市 1而杰森国的首都是城市 N.你只需摧毁位于杰森国首都 的曾·布拉泽大神殿,杰森国的信仰,军队还有一切就都会 ...

随机推荐

  1. IIS7.5 HTTP 错误500.19-Internal Server Error 无法访问请求的页面,因为该页的相关配置数据无效

    IIS7.5 HTTP 错误500.19-Internal Server Error 无法访问请求的页面,因为该页的相关配置数据无效 --------------------------------- ...

  2. Win7 32位安装Oracle11g R2 图解示例

    Win7 32位操作系统安装Oracle11g R2 图解示例.废话不说了,直接上图. 1.下载的两个oracle 11gR2压缩包解压到单独的文件夹中. 2.找到解压的database文件夹中的Se ...

  3. JQuery之validate入门

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  4. 重构改善既有代码设计--重构手法10:Move Method (搬移函数)

    你的程序中,有个函数与其所驻类之外的另一个类进行更多的交流:调用后者,或被后者调用.在该函数最常用引用的类中建立一个有着类似行为的新函数.将旧函数编程一个单纯的委托函数,或是将旧函数完全移除. 动机: ...

  5. Java 中的几种线程池这么用才是对的

    为什么要使用线程池 虽然大家应该都已经很清楚了,但还是说一下.其实归根结底最主要的一个原因就是为了提高性能. 线程池和数据库连接池是同样的道理,数据库连接池是为了减少连接建立和释放带来的性能开销.而线 ...

  6. CF148A Insomnia cure

    公主睡前数龙, 每隔k, l, m, n只都会用不同的技能攻击龙. 假定共数了d只龙, 问共有多少龙被攻击了. 思路: 用一个visit数组记录被攻击过的dragon, 最后遍历visit数组统计被攻 ...

  7. python批量替换文件名

    替换关键字 #-*-coding:utf-8-*- import os import re filepath = u'E:\\CMMI4\\07_测试文档' files = os.walk(filep ...

  8. cordova 从xcode7迁移到xcode8

    环境以开发流程 当前项目使用的cordova环境 cordova 6.1.1 cordova-ios 3.9.2(vs15自动装的不知道在哪能改,所以考虑升级到vs17,能够手动指定) cordova ...

  9. idea关于断点的补充

    黑背景版: 先编译好要调试的程序.1.设置断点

  10. WDCP各种停止重启命令

    service wdapache start|stop|restart    wdcp后台 启动|停止|重起service nginxd start|stop|restart        nginx ...