BFS——珂朵莉的无向图

31 篇文章 0 订阅

BFS——珂朵莉的无向图

题目描述

珂朵莉给了你一个无向图,每次查询给t个点以及一个常数s,求有多少个图中的点距离给出的那t个点中至少一个距离 <= s

输入描述:

第一行三个数表示n,m,q
之后m行每行两个数u,v表示有一条边位于u和v两个点之间
之后 2 x q 行表示询问
每次询问先输入两个数t,s
之后一行t个数,表示t个特殊点

输出描述:

q行,每行一个数表示答案

示例

输入

5 6 6
2 3
1 3
2 5
1 3
3 2
2 5
1 1
3
1 1
1
1 4
1
1 2
5
1 4
1
1 4
5

输出

3
2
4
3
4
4

说明

n,m,q<= 5000 ,t的和<= 500000, s <= 1e9

#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<iostream>
#include<algorithm>
#include<queue>
#include<vector>
using namespace std;
const int maxn=5050;
int vis[maxn],f[maxn];
int n,m,s,num,w,t;
queue<int> q;
vector<int> a[maxn];
int bfs()
{
	int cnt=0;
	while(!q.empty()){
		cnt++;
		int x=q.front();
		q.pop();
		for(int i=0;i<a[x].size();i++){
			int to=a[x][i];
			if(!vis[to]){
				vis[to]=1;
				f[to]=f[x]+1;
				if(f[to]<=s){
					q.push(to);
				}
			}
		}
	}
	return cnt;
}
int main()
{
	cin>>n>>m>>w;
	for(int i=0;i<m;i++){
		int x,y;
		cin>>x>>y;
		a[x].push_back(y);
		a[y].push_back(x);
	}
	for(int i=0;i<w;i++){
		memset(vis,0,sizeof(vis));
		memset(f,0,sizeof(f));
		cin>>t>>s;
		for(int j=0;j<t;j++){
			int x;
			cin>>x;
			if(!vis[x]){
				q.push(x);
				vis[x]=1;
			}
		}
		int ans=bfs();
		cout<<ans<<endl;
	}
	return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值