首页 > 其他分享 >最短路计数

最短路计数

时间:2024-08-02 09:18:24浏览次数:7  
标签:cnt dist int 短路 计数 heap 顶点 ver

// 最短路计数.cpp : 此文件包含 "main" 函数。程序执行将在此处开始并结束。
//


/*
* https://loj.ac/p/10077
【题目描述】
给出一个 N 个顶点 M 条边的无向无权图,顶点编号为 1∼N。问从顶点 1 开始,到其他每个点的最短路有几条。

输入格式
第一行包含 2 个正整数 N,M,为图的顶点数与边数。
接下来 M行,每行两个正整数 x,y,表示有一条顶点 x 连向顶点 y 的边,请注意可能有自环与重边。


【输出】
输出 N 行,每行一个非负整数,第 i 行输出从顶点 1 到顶点 i 有多少条不同的最短路,由于答案有可能会很大,
你只需要输出mod 100003后的结果即可。如果无法到达顶点 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。
*/


#include <iostream>
#include <queue>
#include <vector>
#include <cstring>

using  namespace std;


typedef pair<int, int> PII;

const int N = 100010;
const int M = 400010;
int h[N], e[M], ne[M], idx;
int dist[N];
int cnt[N];
int vis[N];
const int MOD = 100003;

int n, m;


void add(int a, int b) {
	e[idx] = b, ne[idx] = h[a], h[a] = idx++;
}

void solve() {
	memset(dist, 0x3f, sizeof dist);
	memset(cnt,0,sizeof cnt);
	memset(vis, 0, sizeof vis);

	dist[1] = 0;
	cnt[1] = 1;

	priority_queue<PII, vector<PII>, greater<PII>> heap;
	heap.push({ 0, 1 });      // first存储距离,second存储节点编号

	while (heap.size()) {
		auto t = heap.top();
		heap.pop();

		int ver = t.second; int distance = t.first;

		if (vis[ver]) continue;
		vis[ver] = 1;

		for (int i = h[ver]; i != -1; i = ne[i]) {
			int j = e[i];
			if (dist[j] > distance + 1) {
				dist[j] = distance + 1;
				cnt[j] = cnt[ver];
				heap.push({ dist[j],j });
			}
			else if (dist[j] == distance + 1) {
				cnt[j] += cnt[ver];
				cnt[j] %= MOD;
				heap.push({ dist[j],j });
			}
		}
	}

	for (int i = 1; i <= n; i++) {
		cout << cnt[i] << endl;
	}

}

int main()
{
	cin >> n >> m;
	memset(h, -1, sizeof h);
	for (int i = 0; i < m; i++) {
		int a, b; cin >> a >> b;
		add(a, b); add(b, a);
	}

	solve();

	return 0;
}

标签:cnt,dist,int,短路,计数,heap,顶点,ver
From: https://www.cnblogs.com/itdef/p/18337983

相关文章

  • 观光 最短路次短路
    //观光.cpp:此文件包含"main"函数。程序执行将在此处开始并结束。///*https://www.acwing.com/problem/content/description/385/“您的个人假期”旅行社组织了一次比荷卢经济联盟的巴士之旅。比荷卢经济联盟有很多公交线路。每天公共汽车都会从一座城市开往另一......
  • 环计数
    前言本文仅为个人记录,参考价值不大,且仅写了几个例题,以后遇到这方面的题会再补充。三元环计数实现首先显然有\(O(nm)\)的暴力,考虑优化这个过程。将点按度数从小到大排序,若度数相等则按编号大小排序,然后将原来的无向边变为从前往后的有向边,在原图中的三元环\((u,v,w)\)变为......
  • Luogu P1613 跑路 题解 [ 蓝 ] [ 倍增 ] [ Floyd 最短路 ] [ 状压 dp ]
    跑路:绝佳倍增好题,思路是化\(2^k\)为\(1\),倍增起预处理作用。最近不知道是撞了什么运,前一脚看的是绿题,写完之后交一发,发现直接被lxl升蓝了,血赚。思路:Floyd首先观察到每次走\(2^k\)的代价为\(1\),我们可以预处理出每次走\(2^i\)能到哪些点。但为了让这题的代码更好实......
  • 每组具有归一化 y 轴的计数图
    我想知道是否可以创建Seaborn计数图,但不是显示y轴上的实际计数,而是显示其组内的相对频率(百分比)(如hue参数指定)。I使用以下方法解决了这个问题,但我无法想象这是最简单的方法:#Plotpercentageofoccupationperincomeclassgrouped=df.groupby(['income'],......
  • 有没有办法根据 Pandas GroupBy 的计数在 2 个数据帧之间重复分配值?
    我有两个结构相同但形状和值不同的Pandas数据框:importpandasaspddataframe_1=pd.DataFrame({'customer_id':['id1','id2','id3','id4','id5','id6'],'gender':[......
  • 关于最短路、次短路计数
    最短路计数题意给出一个 \(N\) 个顶点 \(M\) 条边的无向无权图,顶点编号为 \(1\) 到 \(N\)。问从顶点 \(1\) 开始,到其他每个点的最短路有几条。分析我们可以用BFS计算出源点\(1\)到其他点的最短距离序列\(dis\),由于BFS弹出队列的顺序是拓扑序,因此在BFS的过......
  • P5825 排列计数 加强版
    加强版和原题不同之处在于\(p\)不再是一个排列,而是一个普通的值域为\([1,n]\)的数组考虑将\([p_i<p_{i+1}]\)转化为\(1-[p_i\gep_{i+1}]\),方便计算后面的\(g\),也就是恰好\(n-k-1\)不上升点的方案数记一段不上升点的连续段为非升段,\(f_i\)表示恰好\(i\)个不上升......
  • 【变压器的开路和短路试验】提供从开路和短路试验中获得的结果电阻性和感性参数(Simuli
      ......
  • 最短路
    floyd——最短路里玩最花的dij——跑得很快spfa——差分约束&费用流01bfs——边权只有两个时候最快求最小环首先floyd中\(f[i][j][k]\)代表从i到j中间只经过编号小于等于k的节点的最小值。那么我们可以想到一个环满足i-j的优弧(类似这么叫),然后剩下一个点编号大于k,直接加上边权......
  • 在 Python 中读取部分 MP3 文件时处理“对于可用位计数来说太大”错误
    我正在尝试读取MP3文件的特定部分,但遇到错误:[src/libmpg123/layer3.c:INT123_do_layer3():1771]error:part2_3_length(1376)toolargeforavailablebitcount(760)可以访问音频文件此处我的环境是使用此Docker映像设置的:pytorc......