题目描述
给出一个 N 个顶点 M 条边的无向无权图,顶点编号为 1 到 N。
问从顶点 1 开始,到其他每个点的最短路有几条。
输入格式
第一行包含 2 个正整数 N,M,为图的顶点数与边数。
接下来 M 行,每行两个正整数 x,y,表示有一条顶点 x 连向顶点 y 的边,请注意可能有自环与重边。
输出格式
输出 N 行,每行一个非负整数,第 i 行输出从顶点 1 到顶点 i 有多少条不同的最短路,由于答案有可能会很大,你只需要输出对 100003 取模后的结果即可。
如果无法到达顶点 i 则输出 0。
数据范围
1 ≤ N ≤ 105,
1 ≤ M ≤ 2×105
输入样例:
5 7
1 2
1 3
2 4
3 4
2 3
4 5
4 5
输出样例:
1
1
1
2
4
解题思路
这种题目在DP的问题中其实也有类似题目(求最优方案以及最优方案数)。这道题也一样可以用DP的思想来分析(闫式DP分析法):用 cnt[i] 表示从 1 号点到 i 点的最短路径条数,那么就有 cnt[i] = cnt[p] + cnt[q] + … + cnt[k],其中p、q、k表示存在边(p->i、q->i、k->i),