推导部分和-图论+dfs+连通块

先研究一下,感觉有点像lca里的树上前缀和,不过树有多颗,用color区分一下

https://www.luogu.com.cn/problem/P8779

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
#define N 100011
typedef  long long ll;
typedef pair<int,int> pii;
int n,k,m,cnt;
typedef struct edge
{
	int v;
	ll w;
}edge ;
vector<edge> mp[N];
int color[N];
ll pre_sum[N];///前缀和 
void dfs(int u,ll d,int cnt)///树上前缀和的思路,color标记不同的树 
{
	pre_sum[u]=d;
	color[u]=cnt;
	for(auto a:mp[u])
	{
		int v=a.v;
		ll w=a.w;
		if(color[v]) continue;
		dfs(v,d+w,cnt);
	}
}
int main()
{
    ios::sync_with_stdio(0);
    cin.tie(0);
    cout.tie(0);
    cin>>n>>m>>k;
    for(int i=0;i<m;i++)
    {
    	int u,v;
    	ll w;
    	cin>>u>>v>>w;
    	mp[u-1].push_back({v,w});///0-5时正的 
    	mp[v].push_back({u-1,-1*w});///5-0是负的 
	}
	
	for(int i=1;i<=n;i++)
	{
		if(!color[i])
		{
			dfs(i,0,++cnt); ///Color来标记和区分不同树 
		}
	}
	while(k--)
	{
		int l,r;
		cin>>l>>r;
		if(color[l-1]!=color[r]) cout<<"UNKNOWN"<<endl;///不在同一棵树 
		else
		{
			cout<<pre_sum[r]-pre_sum[l-1]<<endl;///区间和用树上前缀和来求 
		}
	}
    return 0;
}
相关推荐
6Hzlia3 分钟前
【Hot 100 刷题计划】 LeetCode 51. N 皇后 | C++ 回溯算法&状态数组
c++·算法·leetcode
脱氧核糖核酸__31 分钟前
LeetCode热题100——41.缺失的第一个正数(题解+答案+要点)
数据结构·c++·算法·leetcode·哈希算法
脱氧核糖核酸__31 分钟前
LeetCode热题100——73.矩阵置零(题目+题解+答案)
c++·算法·leetcode·矩阵
Mr_Xuhhh35 分钟前
深入理解单链表的递归反转:从原理到实现
算法·leetcode·职场和发展
智者知已应修善业39 分钟前
【51单片机数码管+蜂鸣器的使用】2023-6-14
c++·经验分享·笔记·算法·51单片机
迷途之人不知返1 小时前
算法类型:双指针类型
算法
吴可可1231 小时前
三点绘圆弧的几何实现
算法
kyle~1 小时前
导航---LIO(激光雷达-惯性里程计)算法
c++·算法·机器人·ros2·导航
AGI前沿1 小时前
# 反内卷,回基础:Nano-Memory用极简检索与剪枝,解决大模型长对话遗忘
算法·机器学习
无限进步_1 小时前
【C++】私有虚函数与多态:访问权限不影响动态绑定
开发语言·c++·ide·windows·git·算法·visual studio