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

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;	

}
相关推荐
CoderCodingNo3 小时前
【NOIP】2011真题解析 luogu-P1003 铺地毯 | GESP三、四级以上可练习
算法
iFlyCai4 小时前
C语言中的指针
c语言·数据结构·算法
查古穆4 小时前
栈-有效的括号
java·数据结构·算法
再一次等风来4 小时前
近场声全息(NAH)仿真实现:从阵列实值信号到波数域重建
算法·matlab·信号处理·近场声全息·nah
汀、人工智能4 小时前
16 - 高级特性
数据结构·算法·数据库架构·图论·16 - 高级特性
大熊背4 小时前
利用ISP离线模式进行分块LSC校正的方法
人工智能·算法·机器学习
XWalnut4 小时前
LeetCode刷题 day4
算法·leetcode·职场和发展
蒸汽求职5 小时前
机器人软件工程(Robotics SDE):特斯拉Optimus落地引发的嵌入式C++与感知算法人才抢夺战
大数据·c++·算法·职场和发展·机器人·求职招聘·ai-native
AI成长日志5 小时前
【笔面试算法学习专栏】双指针专题·简单难度两题精讲:167.两数之和II、283.移动零
学习·算法·面试
旖-旎5 小时前
分治(库存管理|||)(4)
c++·算法·leetcode·排序算法·快速选择算法