【算法】数据结构题单练习(寒假正在更新中)

1. 最小距离和(树的重心)

题目: http://oj.daimayuan.top/course/7/problem/529

复制代码
#include<bits/stdc++.h>
using namespace std;

typedef long long ll;

const int N = 2e5+5;
const int inf = 0x3f3f3f3f;

int n;
int pre[N];
int dist[N];
vector<int> e[N];
int f[N];
int cnt;

//求出每个节点到根节点的距离
void dfs(int x){   
	for(auto y:e[x]){
		if(y!=pre[x]){
			pre[y]=x;
			dist[y]=dist[x]+1;
			dfs(y);
		}
	}
}

//计算以当前节点为根节点的子树中的最大深度
void solve(int x){
	cnt++;
	for(auto y:e[x]){
		if(y!=pre[x]){
			pre[y]=x;
			solve(y);
		}
	}
}

int main(){
	ios::sync_with_stdio(false);
	cin.tie(nullptr);

	cin>>n;
	for(int i=1;i<n;i++){
		int x,y;
		cin>>x>>y;
		e[x].push_back(y);
		e[y].push_back(x);
	}
	
	//对每个节点,计算其子树中的最大深度
	for(int i=1;i<=n;i++){
		f[i]=0;
		memset(pre,0,sizeof(pre));
		for(auto y:e[i]){
			cnt=0;
			pre[y]=i;
			solve(y);
			f[i]=max(f[i],cnt);
		}
	}
	
	//找到直径的根节点,即子树中最大深度的最小的节点
	int idx=0,v=1<<30;
	for(int i=1;i<=n;i++){
		if(f[i]<v){
			v=f[i];
			idx=i;
		}
	}
	memset(dist,0,sizeof(dist));
	memset(pre,0,sizeof(pre));
	pre[idx]=-1;
	dfs(idx);
	v=0;

	//计算以idx为根节点的最小距离和
	int ans=0;
	for(int i=1;i<=n;i++){
		ans+=dist[i];
	}
	cout<<ans<<"\n";
	
	
	return 0;	

}
2. 树的最近公共祖先 (LCA)

题目: http://oj.daimayuan.top/course/7/problem/531

复制代码
#include<bits/stdc++.h>
using namespace std;

typedef long long ll;

const int N = 1001;
const int inf = 0x3f3f3f3f;

int n,m;
int dist[N];
vector<int> e[N];
int fa[N];


//求出每个点与根节点的距离
void dfs(int x){
	for(auto y:e[x]){
		dist[y]=dist[x]+1;
		dfs(y);
	}
}

int main(){
	ios::sync_with_stdio(false);
	cin.tie(nullptr);

	cin>>n;
	for(int i=1;i<n;i++){
		int x,y;
		cin>>x>>y;
		e[x].push_back(y);
		fa[y]=x;
	}
	memset(dist,0,sizeof(dist));
	dfs(1);
	cin>>m;
	for(int i=1;i<=m;i++){
		int x,y;
		cin>>x>>y;
		if(dist[x]<dist[y]){
			swap(x,y);
		}
		int z=dist[x]-dist[y];
		for(int j=1;j<=z;j++){
			x=fa[x];
		}
		while(x!=y){
			x=fa[x];
			y=fa[y];
		}
		cout<<x<<"\n";
	}
	
	
	return 0;	

}
相关推荐
不忘不弃3 分钟前
求两组数的平均值
数据结构·算法
leaves falling4 分钟前
迭代实现 斐波那契数列
数据结构·算法
2401_876907525 分钟前
USB TYPE-C 公头连接器设计规范总结:提升可靠性、降本增效的关键指南
c语言·开发语言·设计规范
珂朵莉MM15 分钟前
全球校园人工智能算法精英大赛-产业命题赛-算法巅峰赛 2025年度画像
java·人工智能·算法·机器人
Morwit23 分钟前
*【力扣hot100】 647. 回文子串
c++·算法·leetcode
tobias.b1 小时前
408真题解析-2009-13-计组-浮点数加减运算
算法·计算机考研·408考研·408真题
Illusionna.1 小时前
C 语言实现独立样本 t 检验和配对样本 t 检验
c语言·编程·统计·统计学·t-test·独立样本t检验·配对样本t检验
菜鸟233号1 小时前
力扣96 不同的二叉搜索树 java实现
java·数据结构·算法·leetcode
龚礼鹏2 小时前
Android应用程序 c/c++ 崩溃排查流程二——AddressSanitizer工具使用
android·c语言·c++
Coovally AI模型快速验证2 小时前
超越Sora的开源思路:如何用预训练组件高效训练你的视频扩散模型?(附训练代码)
人工智能·算法·yolo·计算机视觉·音视频·无人机