1. Description
  2.  
  3. 很久以前,在一个遥远的星系,一个黑暗的帝国靠着它的超级武器统治者整个星系。某一天,凭着一个偶然的机遇,一支反抗军摧毁了帝国的超级武器,并攻下了星系中几乎所有的星球。这些星球通过特殊的以太隧道互相直接或间接地连接。 但好景不长,很快帝国又重新造出了他的超级武器。凭借这超级武器的力量,帝国开始有计划地摧毁反抗军占领的星球。由于星球的不断被摧毁,两个星球之间的通讯通道也开始不可靠起来。现在,反抗军首领交给你一个任务:给出原来两个星球之间的以太隧道连通情况以及帝国打击的星球顺序,以尽量快的速度求出每一次打击之后反抗军占据的星球的连通快的个数。(如果两个星球可以通过现存的以太通道直接或间接地连通,则这两个星球在同一个连通块中)。
  4. Input
  5.  
  6. 输入文件第一行包含两个整数,N (1 <= N <= 2M) M (1 <= M <= 200,000),分别表示星球的数目和以太隧道的数目。星球用0~N-1的整数编号。接下来的M行,每行包括两个整数X, Y,其中(0<=X<>Y
  7. Output
  8.  
  9. 输出文件的第一行是开始时星球的连通块个数。接下来的N行,每行一个整数,表示经过该次打击后现存星球的连通块个数。
  10. Sample Input
  11. 8 13
  12. 0 1
  13. 1 6
  14. 6 5
  15. 5 0
  16. 0 6
  17. 1 2
  18. 2 3
  19. 3 4
  20. 4 5
  21. 7 1
  22. 7 2
  23. 7 6
  24. 3 6
  25. 5
  26. 1
  27. 6
  28. 3
  29. 5
  30. 7
  31. Sample Output
  32. 1
  33. 1
  34. 1
  35. 2
  36. 3
  37. 3

额,不会写,看题解

先预处理出sp[l,r]表示l到r天都能用的最短路

然后dp,f[i,j]表示i到j天的最小花费

f[i,j]=min(f[i,k]+cost+f[k+1,j])

  1. var
  2. sp:array[..,..]of longint;
  3. a:array[..,..]of boolean;
  4. first,next,last,w,q:array[..]of longint;
  5. dis:array[..]of longint;
  6. flag,can:array[..]of boolean;
  7. n,m,k,e,tot,l,r,head,tail:longint;
  8.  
  9. function min(x,y:longint):longint;
  10. begin
  11. if x<y then exit(x);
  12. exit(y);
  13. end;
  14.  
  15. procedure spfa;
  16. var
  17. i,j:longint;
  18. begin
  19. head:=;
  20. tail:=;
  21. q[]:=;
  22. for i:= to m do
  23. dis[i]:=;
  24. dis[]:=;
  25. for i:= to m do
  26. flag[m]:=false;
  27. flag[]:=true;
  28. for i:= to m do
  29. begin
  30. can[i]:=true;
  31. for j:=l to r do
  32. if a[i,j] then can[i]:=false;
  33. end;
  34. while head<=tail do
  35. begin
  36. i:=first[q[head]];
  37. while i<> do
  38. begin
  39. if can[last[i]] then
  40. if dis[last[i]]>dis[q[head]]+w[i] then
  41. begin
  42. dis[last[i]]:=dis[q[head]]+w[i];
  43. if flag[last[i]]=false then
  44. begin
  45. inc(tail);
  46. flag[last[i]]:=true;
  47. q[tail]:=last[i];
  48. end;
  49. end;
  50. i:=next[i];
  51. end;
  52. flag[q[head]]:=false;
  53. inc(head);
  54. end;
  55. sp[l,r]:=dis[m];
  56. end;
  57.  
  58. procedure insert(x,y,z:longint);
  59. begin
  60. inc(tot);
  61. last[tot]:=y;
  62. next[tot]:=first[x];
  63. first[x]:=tot;
  64. w[tot]:=z;
  65. end;
  66.  
  67. procedure init;
  68. var
  69. i,j,x,y,z:longint;
  70. begin
  71. read(n,m,k,e);
  72. for i:= to e do
  73. begin
  74. read(x,y,z);
  75. insert(x,y,z);
  76. insert(y,x,z);
  77. end;
  78. read(e);
  79. for i:= to e do
  80. begin
  81. read(x,y,z);
  82. for j:=y to z do
  83. a[x,j]:=true;
  84. end;
  85. for l:= to n do
  86. for r:=l to n do
  87. spfa;
  88. end;
  89.  
  90. var
  91. f:array[..,..]of longint;
  92.  
  93. procedure work;
  94. var
  95. i,j,l:longint;
  96. begin
  97. for i:= to n do
  98. for j:=i to n do
  99. f[i,j]:=sp[i,j]*(j-i+);
  100. for i:= to n- do
  101. for j:= to n-i do
  102. for l:=j to i+j- do
  103. f[j,i+j]:=min(f[j,i+j],f[j,l]+k+f[l+,i+j]);
  104. write(f[,n]);
  105. end;
  106.  
  107. begin
  108. init;
  109. work;
  110. end.

1003: [ZJOI2006]物流运输trans - BZOJ的更多相关文章

  1. BZOJ 1003 [ZJOI2006]物流运输trans

    1003: [ZJOI2006]物流运输trans Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 4242  Solved: 1765[Submit] ...

  2. BZOJ 1003: [ZJOI2006]物流运输trans(最短路+dp)

    1A,爽! cost[i][j]表示从第i天到第j天不改路线所需的最小花费,这个可以用最短路预处理出.然后dp(i)=cost[j][i]+dp(j-1)+c. c为该路线的花费. --------- ...

  3. 【BZOJ】1003: [ZJOI2006]物流运输trans(SPFA+DP)

    http://www.lydsy.com/JudgeOnline/problem.php?id=1003 这题一开始看是不会的额,,,还是看题解了..一开始我觉得不能用最短路啥的,,看了题解发现这是d ...

  4. BZOJ 1003: [ZJOI2006]物流运输trans DP+最短路

    Description 物流公司要把一批货物从码头A运到码头B.由于货物量比较大,需要n天才能运完.货物运输过程中一般要转停好几个码头.物流公司通常会设计一条固定的运输路线,以便对整个运输过程实施严格 ...

  5. BZOJ 1003 [ZJOI2006]物流运输trans ★(Dijkstra + DP)

    题目链接 http://www.lydsy.com/JudgeOnline/problem.php?id=1003 思路 先Dijkstra暴力求出i..j天内不变换路线的最少花费,然后dp[i] = ...

  6. BZOJ 1003 [ZJOI2006]物流运输trans SPFA+DP

    题意:链接 方法:SPFA+DP 解析:挺好的题目.因为数据范围较小所以用这样的方式能够搞,只是也是挺不好想的. 我们定义cost(i,j)表示从第i天走到第j天运用同一种方式的最小花费,然后因为数据 ...

  7. BZOJ 1003 ZJOI2006 物流运输trans 动态规划+SPFA

    标题效果:给定一个无向图.输送n日,有一天的某一时刻不能去,更换行考虑k,求总成本 一阶cost[i][j]用于第一i为了天j天正在同一航线的最低消费 这种利用SPFA处理 然后就是移动的法规问题 订 ...

  8. 【BZOJ1003】1003: [ZJOI2006]物流运输trans SPFA+DP

    Description 物流公司要把一批货物从码头A运到码头B.由于货物量比较大,需要n天才能运完.货物运输过程中一般要转停好几个码头.物流公司通常会设计一条固定的运输路线,以便对整个运输过程实施严格 ...

  9. 1003: [ZJOI2006]物流运输trans

    spfa+dp; 刚刚开始一直想不通怎么判断他是否换了道: 后来才知道,将那个时间段打包,找出这段时间内的最短路: 真是太奇妙了! #include<cstdio> #include< ...

随机推荐

  1. jquery的datepicker汉化

    $("#date").datepicker({ dateFormat: "yy-mm-dd", monthNames:["1月", &quo ...

  2. css3 web字体记

    css3 web字体 @font-face语法 @font-face能够加载服务器端的字体,让客户端浏览器显示客户端没有安装的字体. @font-face{ font-family:<YourW ...

  3. Intent的属性介绍

    在Android系统的设计中有四大组件:Activity,Service,BroadcastReceiver,ContentProvider.Intent可以被应用于ContentProvider之外 ...

  4. js解析json读取List中的实体对象示例

    1.由后台action 传给前台是需要将map 转成json格式 复制代码代码如下: Map<String, List> resultMap: JSONObject json = JSON ...

  5. python学习day1--python基础

    Python的优缺点 先看优点 Python的定位是“优雅”.“明确”.“简单”,所以Python程序看上去总是简单易懂,初学者学Python,不但入门容易,而且将来深入下去,可以编写那些非常非常复杂 ...

  6. c# DateTime时间格式和JAVA时间戳格式相互转换

    /// java时间戳格式时间戳转为C#格式时间 public static DateTime GetTime(long timeStamp) { DateTime dtStart = TimeZon ...

  7. (转)Facebook内部分享:26个高效工作的小技巧

    春节假期马上就要结束了,该收收心进入新一年的工作节奏了~分享 26 个高效工作的小技巧,希望对大家有所帮助~(我发现自己只有最后一条执行得很好,并且堪称完美!) 1.时间常有,时间优先. 2.时间总会 ...

  8. 停车场管理软件附带源代码 J2EE服务端+android客户端

    该源码是停车场管理软件附带源代码 J2EE服务端+android客户端,也是一套停车场管理车辆进出的管理软,喜欢的朋友可以看看吧. 应用的后台管理主要功能介绍:1  机构管理 ,机构有从属管理< ...

  9. WeX5是主要进行app开发吗?能开发微信App吗?

    WeX5是一款html5开发工具,可以进行app开发,做出各种H5 App,同样也可以进行主要运行在PC的html5产品,. WeX5开发的应用,不仅可以在微信上运行,也可以直接手机浏览器运行,或者打 ...

  10. php session的应用举例

    本文原始链接:http://www.jbxue.com/article/9281.html 1,session可以保存任意类型的数据.因为是保存在服务器上的(即已经序列化). 2,session运行机 ...