LOJ10077
题目描述
给出一个 N 个顶点 M 条边的无向无权图,顶点编号为 1∼N。问从顶点 1 开始,到其他每个点的最短路有几条。
输入格式
第一行包含 2 个正整数 N,M,为图的顶点数与边数。
接下来 M行,每行两个正整数 x,y,表示有一条顶点 x 连向顶点 y 的边,请注意可能有自环与重边。
输出格式
输出 N 行,每行一个非负整数,第 i 行输出从顶点 1 到顶点 i 有多少条不同的最短路,由于答案有可能会很大,你只需要输出 mod100003 后的结果即可。如果无法到达顶点 i则输出 0。
样例
样例输入
5 7
1 2
1 3
2 4
3 4
2 3
4 5
4 5
样例输出
1
1
1
2
4
样例解释
1 到 5 的最短路有 4 条,分别为 2 条 1→2→4→5 和 2 条 1→3→4→5(由于 4→5 的边有 2 条)。
数据范围与提示
对于 20% 的数据,N≤100;
对于 60% 的数据,N≤1000;
对于 100% 的数据,1≤N≤100000,0≤M≤200000。
-------------------------------------------------------------------------------------------------------------------------
dij求最短路,增加数组cs[ ],用于统计对应点的最短路径条数。
如果刚计算出最短路,则 cs[v]=cs[u]。
如果最短路已经计算出切新计算的最短路与之相同,那么 cs[v]+=cs[u];
注意记得取模。
-------------------------------------------------------------------------------------------------------------------------
1 #include<bits/stdc++.h>
2 using namespace std;
3 typedef long long ll;
4 const int maxn=1e5+10;
5 const int maxm=2e5+10;
6 int n,m;
7 struct edge
8 {
9 int u,v,w,nxt;
10 }e[maxm<<1];
11 int head[maxn],js;
12 void addage(int u,int v)
13 {
14 e[++js].u=u;e[js].v=v;e[js].w=1;
15 e[js].nxt=head[u];head[u]=js;
16 }
17 ll dis[maxn],cs[maxn];
18 bool vis[maxn];
19 struct node
20 {
21 int p,dis;
22 bool operator < (node b)const
23 {
24 return dis>b.dis;
25 }
26 };
27 void dij(int x)
28 {
29 memset(dis,0x3f,sizeof dis);
30 memset(cs,0,sizeof cs);
31 dis[x]=0;cs[x]=1;
32 priority_queue<node>q;
33 q.push((node){x,0});
34 while(!q.empty())
35 {
36 node t=q.top();
37 q.pop();
38 int u=t.p,d=t.dis;
39 if(vis[u])continue;
40 vis[u]=1;
41 for(int i=head[u];i;i=e[i].nxt)
42 {
43 int v=e[i].v;
44 if(dis[v]>dis[u]+e[i].w)
45 {
46 dis[v]=dis[u]+e[i].w;
47 cs[v]=cs[u];
48 q.push((node){v,dis[v]});
49 }
50 else if(dis[v]==dis[u]+e[i].w) cs[v]=(cs[v]+cs[u])%100003;
51 }
52 }
53 }
54 int main()
55 {
56 scanf("%d%d",&n,&m);
57 for(int u,v,i=0;i<m;++i)
58 {
59 scanf("%d%d",&u,&v);
60 addage(u,v);addage(v,u);
61 }
62 dij(1);
63 for(int i=1;i<=n;++i)printf("%lld\n",cs[i]);
64 return 0;
65 }
LOJ10077的更多相关文章
随机推荐
- 转载--对batch normalization的理解
转载的大神的: https://www.cnblogs.com/guoyaohua/p/8724433.html 上边这个应该是抄的下边这个原文,但是上边的有重点标记 https://blog.csd ...
- cmake的安装
安装cmake有2种方式 安装方式1:源码安装 1.下载cmake源码包(https://cmake.org/download/),解压后进入解压目录 2.执行安装配置命令:配置软件二进制安装到/us ...
- 第二章 信号量及条件变量(三)——> 重点
2.4.4 信号量的应用 1. 利用信号量实现进程互斥 为使多个进程能互斥的访问某临界资源,只需为该资源设置一个互斥信号量mutex,并设置其初值为 1 ,然后讲个进程访问该资源的临界区CS置于w ...
- python常用操作和内置函数
一.常用数据处理方法. 1.索引:按照号码将对应位置的数据取出使用 2.list将任意类型数据用逗号分割存在列表中 3.range:产生一堆数字(顾头不顾尾) 4.切片:可以从复制数据的一部分,不影响 ...
- [ABP教程]第四章 集成测试
Web应用程序开发教程 - 第三章: 集成测试 //[doc-params] { "UI": ["MVC","NG"], "DB& ...
- Linux下docker中安装宝塔面板教程
本人云服务器,装的cent os7.6,在cent os7.6已装了docker,没装的可以借鉴 https://www.cnblogs.com/xiaoyige/p/12673076.html 1. ...
- python3 处理列表嵌套字典去重
def list_dict(dictlist): def function(date): return date['ip'] dictlist_new = [] for list_dict in di ...
- shellSyntax.md
shell #! /bin/bash 头文件 echo -e 若字符串出现特殊字符,则特别处理 -n 不要在最后自动换行 ./filename.sh sh filename.sh r ...
- java的重载与重写
原文链接http://zhhll.icu/2020/11/11/java%E5%9F%BA%E7%A1%80/%E9%9D%A2%E5%90%91%E5%AF%B9%E8%B1%A1/%E9%87%8 ...
- 【C++】《Effective C++》第三章
第三章 资源管理 条款13:以对象管理资源 当申请一块动态内存时,可能会发生内存泄漏. class Investment {}; void f() { Investment* pInv = creat ...