2750: [HAOI2012]Road

Time Limit: 10 Sec  Memory Limit: 128 MB
Submit: 728  Solved: 349
[Submit][Status][Discuss]

Description

C国有n座城市,城市之间通过m条单向道路连接。一条路径被称为最短路,当且仅当不存在从它的起点到终点的另外一条路径总长度比它小。两条最短路不同,当且仅当它们包含的道路序列不同。我们需要对每条道路的重要性进行评估,评估方式为计算有多少条不同的最短路经过该道路。现在,这个任务交给了你。

Input

第一行包含两个正整数n、m
接下来m行每行包含三个正整数u、v、w,表示有一条从u到v长度为w的道路

Output

输出应有m行,第i行包含一个数,代表经过第i条道路的最短路的数目对1000000007取模后的结果

Sample Input

4 4
1 2 5
2 3 5
3 4 5
1 4 8

Sample Output

2
3
2
1

HINT

数据规模

30%的数据满足:n≤15、m≤30

60%的数据满足:n≤300、m≤1000

100%的数据满足:n≤1500、m≤5000、w≤10000

Source

显示代码纯文本

  1. #include<cstdio>
  2. #include<cstring>
  3. #include<queue>
  4. #define pir pair<int,int>
  5. using namespace std;
  6. const int N=;
  7. const int inf=0x3f3f3f3f;
  8. const int mod=1e9+;
  9. struct edge{int v,w,next;}e[N<<];int tot,head[N];
  10. int n,m,dis[N],cnt[N],sum[N],ans[N*],q[N*];bool vis[N*];
  11. void add(int x,int y,int z){
  12. e[++tot].v=y;e[tot].w=z;e[tot].next=head[x];head[x]=tot;
  13. }
  14. void dijkstra(int S){
  15. memset(dis,inf,(n+)<<);
  16. memset(vis,,(n+)<<);
  17. memset(cnt,,(n+)<<);cnt[S]=;
  18. priority_queue<pir,vector<pir>,greater<pir> >q;
  19. q.push(make_pair(dis[S]=,S));
  20. while(!q.empty()){
  21. pir t=q.top();q.pop();
  22. int x=t.second;
  23. if(vis[x]) continue;
  24. vis[x]=;
  25. for(int i=head[x];i;i=e[i].next){
  26. if(!vis[e[i].v]&&dis[e[i].v]>dis[x]+e[i].w){
  27. dis[e[i].v]=dis[x]+e[i].w;
  28. cnt[e[i].v]=cnt[x];
  29. q.push(make_pair(dis[e[i].v],e[i].v));
  30. }
  31. else if(dis[e[i].v]==dis[x]+e[i].w){
  32. cnt[e[i].v]+=cnt[x];
  33. cnt[e[i].v]%=mod;
  34. }
  35. }
  36. }
  37. }
  38. int dfs(int x){
  39. if(sum[x]) return sum[x];
  40. sum[x]=;
  41. for(int i=head[x];i;i=e[i].next){
  42. if(dis[e[i].v]!=dis[x]+e[i].w) continue;
  43. sum[x]+=dfs(e[i].v);
  44. ans[i]+=sum[e[i].v]*cnt[x];
  45. ans[i]%=mod;
  46. }
  47. return sum[x];
  48. }
  49. void init(){
  50. scanf("%d%d",&n,&m);
  51. for(int i=,x,y,z;i<=m;i++){
  52. scanf("%d%d%d",&x,&y,&z);
  53. add(x,y,z);
  54. }
  55. }
  56. void work(){
  57. for(int i=;i<=n;i++){
  58. memset(sum,,(n+)<<);
  59. dijkstra(i);
  60. dfs(i);
  61. }
  62. for(int i=;i<=m;i++) printf("%d\n",ans[i]);
  63. }
  64. int main(){
  65. freopen("roadsw.in","r",stdin);
  66. freopen("roadsw.out","w",stdout);
  67. init();
  68. work();
  69. return ;
  70. }

[HAOI2012]Road的更多相关文章

  1. BZOJ2750: [HAOI2012]Road

    2750: [HAOI2012]Road Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 261  Solved: 113[Submit][Status ...

  2. BZOJ 2750: [HAOI2012]Road( 最短路 )

    对于每个点都跑最短路, 然后我们得到了个DAG, 在这DAG上更新每条边的答案. 考虑e(u, v)∈DAG对答案的贡献:  假设从S到u得路径数为A[u], 从v出发到达任意点的路径数为B[v], ...

  3. bzoj 2750: [HAOI2012]Road

    Description C国有n座城市,城市之间通过m条单向道路连接.一条路径被称为最短路,当且仅当不存在从它的起点到终点的另外一条路径总长度比它小.两条最短路不同,当且仅当它们包含的道路序列不同.我 ...

  4. bzoj 2750: [HAOI2012]Road【spfa+dfs】

    枚举起点做spfa,然后一条边在最短路上的条件是dis[e[i].to]==dis[u]+e[i].va,所以每次spfa完之后,dfs出a[i]表示经过i点的最短路的起点数,b[i]表示经过i点的最 ...

  5. 【BZOJ】【2750】【HAOI2012】Road

    最短路+拓扑序DP orz zyf & lyd 统计每条边在多少条最短路径上……其实可以统计 有多少条最短路径经过了x,以及y出发到达任意一个结束点有多少种走法(沿最短路) 我们可以用Dijk ...

  6. bzoj AC倒序

    Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...

  7. BZOJ2752: [HAOI2012]高速公路(road)

    2752: [HAOI2012]高速公路(road) Time Limit: 20 Sec  Memory Limit: 128 MBSubmit: 608  Solved: 199[Submit][ ...

  8. BZOJ 2752: [HAOI2012]高速公路(road)( 线段树 )

    对于询问[L, R], 我们直接考虑每个p(L≤p≤R)的贡献,可以得到 然后化简一下得到 这样就可以很方便地用线段树, 维护一个p, p*vp, p*(p+1)*vp就可以了 ----------- ...

  9. 【线段树】BZOJ2752: [HAOI2012]高速公路(road)

    2752: [HAOI2012]高速公路(road) Time Limit: 20 Sec  Memory Limit: 128 MBSubmit: 1621  Solved: 627[Submit] ...

随机推荐

  1. WCF调试异常信息:ServiceHost 仅支持类服务类型

    "/CommonHelpServices"应用程序中的server错误. ServiceHost 仅支持类服务类型. 说明: 运行当前 Web 请求期间,出现未经处理的异常. 请检 ...

  2. Spine U3D整合流程问题

    Spine U3D整合流程问题 What: 公司2d项目开发,动画外包的spine.本来在spine里面一切正常,但是导入u3d运行库的时候动画切换的时候原来的动画是好的,一旦切换了就乱帧了. 如下结 ...

  3. sql中limit和汇总函数的集合使用

    limit和求和一起 select SUM(A.high) from (select * from minute1_K order by DateTime desc limit 10) A limit ...

  4. 《从零開始学Swift》学习笔记(Day 57)——Swift编码规范之凝视规范:文件凝视、文档凝视、代码凝视、使用地标凝视

    原创文章.欢迎转载.转载请注明:关东升的博客 前面说到Swift凝视的语法有两种:单行凝视(//)和多行凝视(/*...*/).这里来介绍一下他们的使用规范. 1.文件凝视 文件凝视就在每个文件开头加 ...

  5. cookie 与 session 的差别、联系

    1.存放位置: Session 存放在server端. Cookie 存放在client: 2.保存形式: Session保存在server的内存中(在server端设置超时时间,与浏览器设置无关): ...

  6. win10 VS code 编译运行 C/C++的方法

    具体配置过程如下链接: https://zhuanlan.zhihu.com/p/35178331 但中间出了点问题:CTRL+ALT+n 运行后: PS D:\C++> cd "d: ...

  7. WCF RIA Services使用详解(转载)

    理解领域服务和领域操作 本文目录: 3.1 WCF Ria Services简介 3.1.1 什么是WCF Ria Services 3.1.2 WCF Ria Services如何生成客户端代码 3 ...

  8. C++之栈、队列基本用法

    1.C++栈的基本用法: #include<stack> (1)push():向栈内压入一个成员: (2)pop():栈顶弹出一个成员: (3)empty():栈为空返回true,否则返回 ...

  9. Effective C++ 条款47

    本节条款的题目:请使用trait classes来表示类型信息 本节条款主要讲述的技术是怎样在编译期间实现对迭代器类型的推断,依据推断的类型进行最优处理. 我们先来看一下迭代器的种类: 1.input ...

  10. cURL命令行工具请求网页

    http://curl.haxx.se/download.html curl非常博大,用户要想使用好这个工具,除了详细学习参数之外,还需要深刻理解http的各种协议与URL的各个语法. 这里推荐几个读 ...