ABC 373

D. Hidden Weights

(1)不同连通块不会产生影响,每个连通块各自处理

(2)有向图是没法 dfs 的,任选一个为起点,那么走向这个起点的点所在子图就遍历不到,所以第一步先把无向图改为有向图:u ---> v 边权 w 等价于 v ---> u 边权 - w。每次加边同时加反向负边

(3)对每个连通块,任意一个起点,点权设为 0,然后往外推。v - u = w 就是 v = u + w

复制代码
#include<bits/stdc++.h>
#define int long long
using namespace std;
const int N = 2e5 + 5, INF = 1e18;

struct node
{
	int v, w;
};

int T, n, m, ans[N], vis[N];
vector<node> G[N];

void dfs(int u)
{
	vis[u] = 1;
	for (auto x : G[u])
	{
		int v = x.v, w = x.w;
		if (vis[v] == 0)
		{
			ans[v] = ans[u] + w;
			dfs(v);
		}
	}
}

signed main()
{
	cin >> n >> m;
	for (int i = 1; i <= m; i ++)
	{
		int u, v, w;
		cin >> u >> v >> w;
		G[u].push_back({v, w}), G[v].push_back({u, -w});
	}
	for (int i = 1; i <= n; i ++)
		if (vis[i] == 0)
		{
			ans[i] = 0;
			dfs(i);
		}
	for (int i = 1; i <= n; i ++)
		cout << ans[i] << ' ';
	return 0;
}
相关推荐
_日拱一卒几秒前
LeetCode:除了自身以外数组的乘积
数据结构·算法·leetcode
计算机安禾5 分钟前
【数据结构与算法】第36篇:排序大总结:稳定性、时间复杂度与适用场景
c语言·数据结构·c++·算法·链表·线性回归·visual studio
SatVision炼金士11 分钟前
合成孔径雷达干涉测量(InSAR)沉降监测算法体系
算法
wuweijianlove14 分钟前
算法稳定性与数值误差传播研究的技术2
算法
计算机安禾37 分钟前
【数据结构与算法】第35篇:归并排序与基数排序
c语言·数据结构·vscode·算法·排序算法·哈希算法·visual studio
爱码小白1 小时前
MySQL 单表查询练习题汇总
数据库·python·算法
橘颂TA1 小时前
【笔试】算法的暴力美学——牛客 NC213140 :除2!
c++·算法·结构与算法
汀、人工智能1 小时前
[特殊字符] 第66课:跳跃游戏
数据结构·算法·数据库架构·图论·bfs·跳跃游戏
汀、人工智能1 小时前
[特殊字符] 第70课:加油站
数据结构·算法·数据库架构·图论·bfs·加油站
wsoz2 小时前
Leetcode普通数组-day5、6
c++·算法·leetcode·数组