基于倍增的LCA + kruskal重构树 + 并查集

P2245 星际导航

cpp 复制代码
//基于倍增的LCA + kruskal重构树 + 并查集
#include<bits/stdc++.h>
#define endl '\n'
#define rep(_start_,_end_) for(int i =  _start_;i <= (_end_);i ++)
#define all0(x) (x).begin(),(x).end()
#define all1(x) (x).begin() + 1,(x).end()
using namespace std;
using ll = long long;

const int N = 1e5 + 10; // 原图最大顶点数
const int M = 5e5 + 10; // 原图最大边数

int n, m, q;
int par[N * 2];
int val[N * 2];//非叶子的权值
vector<int>trie[N * 2];


struct EDGE
{
	int u, v, w;
};

int Find(int x)
{
	return (par[x] == x) ? x : par[x] = Find(par[x]);
}
int new_node;
void build_kruskal(vector<EDGE>&edge)
{
	//初始化
	for(int i = 1;i <= 2 * n - 1;i ++)
		par[i] = i;
	//遍历所有边
	new_node = n;
	for(auto &[l,r,w] : edge)
	{
		int rootl = Find(l);
		int rootr = Find(r);
		
		if(rootl != rootr)
		{
			new_node ++;
			val[new_node] = w;
//			cout << "newnode: "<<new_node <<endl;
			trie[new_node].push_back(rootl);
			trie[new_node].push_back(rootr);
			
			par[rootl] = new_node;
			par[rootr] = new_node;
		}
	}
}


int dep[N * 2],fa[N * 2][20];

void dfs(int u,int u_father)
{

	dep[u] = dep[u_father] + 1;
	fa[u][0] = u_father;
	
	for(int j = 1;j <= 19;j ++)
	{
		fa[u][j] = fa[fa[u][j - 1]][j - 1];
	}
	
	for(auto v:trie[u])
	{
		if(v != u_father)
		{
			dfs(v,u);
		}
	}
}


int get_lca(int l,int r)
{
	if(dep[l] < dep[r])swap(l,r);
	for(int i = 19;i >= 0;i --)
	{
		if(dep[fa[l][i]] >= dep[r])
			l = fa[l][i];
	}
	
	if(l == r)return l;
	
	for(int i = 19;i >= 0;i --)
	{
		if(fa[l][i] != fa[r][i])
			l = fa[l][i],r = fa[r][i];
	}
	return fa[l][0];
}

void solve()
{
	cin >> n >> m; 
	vector<EDGE> edge(m);
	rep(0, m - 1) cin >> edge[i].u >> edge[i].v >> edge[i].w;
	
	sort(all0(edge), [](const auto&i, const auto&j){
		return i.w < j.w;
	});
	//重构树
	build_kruskal(edge);
	//预处理dfs
	for(int i = 1;i <= new_node ;i ++)
	{
		if(par[i] == i)
		{
			dfs(i,0);
		}
	}
//	for(int i = 1;i <= 2 * n - 1;i ++)cout << fa[i][0]<<" ";
//	cout << endl;
	cin >> q;
	while(q --)
	{
		int l,r;
		cin >> l >> r;
		if(Find(l) != Find(r))
			cout << "impossible"<<endl;
		else{
			cout << val[get_lca(l,r)] <<endl;
		}
	}
}

int main()
{
	ios_base::sync_with_stdio(false);
	cin.tie(NULL);
	int t;
	// cin >> t;
	t = 1;
	
	while(t --)
	{
		solve();
	}
	return 0;
}
相关推荐
秋邱13 小时前
智启未来:AGI 教育融合 × 跨平台联盟 × 个性化空间,重构教育 AI 新范式开篇:一场 “教育 ×AI” 的范式革命
人工智能·python·重构·推荐算法·agi
AI产品测评官3 天前
2025年招聘系统后端重构:为什么我们放弃了传统SaaS,转向了LLM+RPA智能体?
重构·rpa
司铭鸿3 天前
祖先关系的数学重构:从家谱到算法的思维跃迁
开发语言·数据结构·人工智能·算法·重构·c#·哈希算法
Ace_31750887764 天前
微店商品详情接口深度挖掘:从多接口联动到数据全息重构
大数据·python·重构
Tezign_space6 天前
技术破局:人机协作如何重构内容生产流水线,实现成本与效能的范式转移
人工智能·重构·降本增效·人机协作·内容数字化·内容科技·内容+人工智能
数字孪生家族6 天前
视频孪生与空间智能:重构数字时空认知,定义智能决策新范式
人工智能·重构·空间智能·视频孪生与空间智能
科技测评-阿博7 天前
基于企业知识图谱的B2B金融获客模型:从“流量思维”到“数据工程”的重构
金融·重构·知识图谱
qqxhb7 天前
零基础MCP——第5章编程实战基础(网页、数据分析、调试与重构)
重构·数据挖掘·数据分析·多模态·mcp
老蒋新思维8 天前
创客匠人 2025 高峰论谈(11.22-25):AI 智能体重构创始人 IP 打造与知识变现的管理逻辑
大数据·网络·人工智能·网络协议·tcp/ip·重构·知识付费
"YOUDIG"9 天前
AI重构虚拟都市美学:探索GTA风格照片生成网站的创意狂想与技术内核
人工智能·重构