机房——蓝桥杯十三届2022国赛大学B组真题

问题分析

这题用深搜广搜都能做,不过我更倾向于用广搜,因为广搜能更容易找到目标点。那么是采用结构体存储边还是采用二维数组存储临接矩阵呢?我们注意到n的取值范围为1e5,用二维数组哪怕是bool类型就需要至少1e10Byte的连续空间,这个空间太大了,申请不了,所有不能用二维数组。(悄悄告诉你,其实是可以的申请一个1e4 × \times × 1e4的二维数组,也能过,大概测试点的n值不会到达1e5,这属于出题人的失误了哈哈哈,他的意思还是想我们用结构体存储边来存储图的)

AC_Code

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
vector<int> vec(N,0);//vec[i]:i结点有多少个邻接边
int n,m,a,b,result;
struct ed{
	int a,b;//两端结点
};
vector<ed> eds;//存储所有边
int bfs(int a,int b){
	if(a==b)return vec[a];//若起终相同
	queue<int> que;
	que.push(a);
	vector<int> visit(n+1,-1);//记录该点到各点的距离,初始化为-1
	visit[a]=vec[a];
	while(!que.empty()){
		int now=que.front();
		que.pop();
		for(int i=0;i<eds.size();i++){
			if(eds[i].a==now&&visit[eds[i].b]==-1){//如果该边与该点邻接且另一端未访问
				visit[eds[i].b]=visit[now]+vec[eds[i].b];//更新
				if(eds[i].b==b){//若达到目标点则返回
					return visit[b];
				}
				que.push(eds[i].b);
			}
		}
	}
	return visit[b];
}
int main() {
	
	cin>>n>>m;
	for(int i=0;i<n-1;i++){
		cin>>a>>b;
		eds.push_back({a,b});//a------>b
		eds.push_back({b,a});//b------>a
		vec[a]++;
		vec[b]++;
	}
	for(int i=0;i<m;i++){
		cin>>a>>b;
		cout<<bfs(a,b)<<endl;
	}
	return 0;
}
相关推荐
雪域迷影20 分钟前
C++中编写UT单元测试用例时如何mock非虚函数?
开发语言·c++·测试用例·gmock·cpp-stub开源项目
sheeta19982 小时前
LeetCode 每日一题笔记 日期:2025.11.24 题目:1018. 可被5整除的二进制前缀
笔记·算法·leetcode
是小胡嘛5 小时前
C++之Any类的模拟实现
linux·开发语言·c++
Want5957 小时前
C/C++跳动的爱心①
c语言·开发语言·c++
lingggggaaaa7 小时前
免杀对抗——C2远控篇&C&C++&DLL注入&过内存核晶&镂空新增&白加黑链&签名程序劫持
c语言·c++·学习·安全·网络安全·免杀对抗
phdsky8 小时前
【设计模式】建造者模式
c++·设计模式·建造者模式
H_-H8 小时前
关于const应用与const中的c++陷阱
c++
coderxiaohan8 小时前
【C++】多态
开发语言·c++
gfdhy8 小时前
【c++】哈希算法深度解析:实现、核心作用与工业级应用
c语言·开发语言·c++·算法·密码学·哈希算法·哈希
百***06018 小时前
SpringMVC 请求参数接收
前端·javascript·算法