是否存在路径(FIFOBB算法)

题目描述

一个具有 n 个顶点e条边的无向图,该图顶点的编号依次为0到n-1且不存在顶点与自身相连的边。请使用FIFOBB算法编写程序,确定是否存在从顶点 source到顶点 destination的路径。

输入

第一行两个整数,分别表示n 和 e 的值(1 <= n <= 2 * 10^5, 0 <= e <= 2 * 10^5);

下面e行,每行两个整数,分别表示一条边的两个顶点;

最后一行两个整数,分别表示 source 和 destination的值。

输出

若存在从顶点 source到顶点 destination的路径,则输出true;否则,输出false。

样例输入 Copy

3 3

0 1

1 2

2 0

0 2

样例输出 Copy

true

复制代码
#include<bits/stdc++.h>
using namespace std;
int n,e;
int main ()
{
	cin>>n>>e;
	vector<vector<int>> graph(n);
	for(int i=0;i<e;i++)
	{
		int u,v;
		cin>>u>>v;
		graph[u].push_back(v);
		graph[v].push_back(u);
	}
	int s,d;
	cin>>s>>d;
	if(s==d)
	{
		cout<<"true"<<endl;
		return 0;
	}
	vector<bool>visited(n,false);
	queue<int>q;
	q.push(s);
	visited[s]=true;
	while(!q.empty())
	{
		int current=q.front();
		q.pop();
		for(int i=0;i<graph[current].size();i++)
		{
			int jb=graph[current][i];
			if(!visited[jb])
			{
				if(jb==d)
				{
					cout<<"true"<<endl;
					return 0;
				}
				visited[jb]=true;
				q.push(jb);
			}
		}
	}
	cout<<"false"<<endl;
	return 0;
}
//by crtzk7
相关推荐
努力也学不会java1 小时前
【缓存算法】一篇文章带你彻底搞懂面试高频题LRU/LFU
java·数据结构·人工智能·算法·缓存·面试
旖-旎1 小时前
二分查找(x的平方根)(4)
c++·算法·二分查找·力扣·双指针
ECT-OS-JiuHuaShan1 小时前
朱梁万有递归元定理,重构《易经》
算法·重构
智者知已应修善业2 小时前
【51单片机独立按键控制数码管移动反向,2片74CH573/74CH273段和位,按键按下保持原状态】2023-3-25
经验分享·笔记·单片机·嵌入式硬件·算法·51单片机
khddvbe2 小时前
C++并发编程中的死锁避免
开发语言·c++·算法
C羊驼2 小时前
C语言:两天打鱼,三天晒网
c语言·经验分享·笔记·算法·青少年编程
菜菜小狗的学习笔记3 小时前
剑指Offer算法题(四)链表
数据结构·算法·链表
myloveasuka3 小时前
[Java]查找算法&排序算法
java·算法·排序算法
清水白石0083 小时前
Free-Threaded Python 实战指南:机遇、风险与 PoC 验证方案
java·python·算法
We་ct3 小时前
LeetCode 148. 排序链表:归并排序详解
前端·数据结构·算法·leetcode·链表·typescript·排序算法