以数据结构之——树来体会深度优先搜索【dfs】和广度优先搜索【bfs】的妙用:学比特算法课的自用笔记

目录

声明:学比特算法课后的自用笔记。

一、深度优先搜索算法就是一条路走到黑再回头,不撞南墙不回头。

树中的dfs思想:

例题:【输出深度优先搜索的结果】

运行的结果图:

可执行代码+注释:

运行结果:

输入:

输入+输出:

二、广度优先搜索算法也叫宽度优先搜索算法也叫层序遍历:就是从根节点往子节点一层一层从左往后的去遍历。

树中的bfs思想:

以上面的那个例题为例:【输出广度优先搜索的结果】

运行后的效果图:

可执行代码+注释:

运行结果:

输入:

输入+输出:


声明:学比特算法课后的自用笔记。

一、深度优先搜索算法就是一条路走到黑再回头,不撞南墙不回头。

树中的dfs思想:

例题:【输出深度优先搜索的结果】

运行的结果图:

可执行代码+注释:

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
const unsigned long long N=1e6+10;
long long n;
vector<long long> edges[N];//由于可能是无根树【不确定哪一个是父节点,所以每一个顶点的容器中包含了直接边相连的所有顶点,然后输出一个排除一个顶点】 
bool st[N];//为了避免同一个顶点多次被输出,所以每一个已输出的顶点都做好标记,以后不会再被访问到 
void dfs(long long u){//深度优先搜索的核心代码 
	cout<<u<<" ";
	st[u]=true;//将已输出的代码做好标记 
	for(vector<long long>::iterator it=edges[u].begin();it!=edges[u].end();it++){//遍历u这个顶点的所有边相连顶点 
		if(st[*it]==false) dfs(*it);
	}
}
int main(){
cin>>n;//输入n个顶点 
while(n>1){//n个顶点的树有n-1条边 
	long long a=0,b=0;
	cin>>a>>b;//n-1条边中的每条边两端的顶点分别是a和b 
	edges[a].push_back(b);
	edges[b].push_back(a);
	n--;
}
dfs(1);//deep深度,所以dfs是深度优先搜索,第一个访问的节点。 
	return 0;
}

运行结果:

输入:

输入+输出:

二、广度优先搜索算法也叫宽度优先搜索算法也叫层序遍历:就是从根节点往子节点一层一层从左往后的去遍历。

树中的bfs思想:

以上面的那个例题为例:【输出广度优先搜索的结果】

运行后的效果图:

可执行代码+注释:

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
const unsigned long long N=1e6+10;
long long n;
vector<long long> edges[N];//由于可能是无根树【不确定哪一个是父节点,所以每一个顶点的容器中包含了直接边相连的所有顶点,然后输出一个排除一个顶点】 
queue<long long> p;//采用队列的方式,一层一层的入队,当本层都入队后,输出该层的左边元素并入队该元素的子节点,一步步来,当队空时广度优先搜索就结束了 
bool st[N];
void bfs(){
	p.push(1);
	while(!p.empty()){//如果队列不为空就一直循环入队出队的操作 
		if(!st[p.front()]){//队头的这个元素没有输出过,并且它已经没有同层(行)的节点了,可以输出了 
		cout<<p.front()<<" ";
		st[p.front()]=true;//队头的这个元素已经被输出过了,所以打上标记,以后遇到这个元素不能再重复输出了 
		int u=p.front();
		p.pop();//队头元素的作用用完了,该输出了 
		for(vector<long long>::iterator it=edges[u].begin();it!=edges[u].end();it++){//输出队头的同时入队队头的子节点 
			if(!st[*it]){
				p.push(*it);
			}
		}
		}
		
	}
}
int main(){
cin>>n;//输入n个顶点 
while(n>1){//n个顶点的树有n-1条边 
long long a,b;
cin>>a>>b;
edges[a].push_back(b);
edges[b].push_back(a);
n--;
}
bfs();
	return 0;
}

运行结果:

输入:

输入+输出:

相关推荐
lwf0061643 小时前
导数学习日记
学习·算法·机器学习
qeen873 小时前
【编程日记】现阶段总结
学习
万法若空5 小时前
C++ <memory> 库全方位详解
开发语言·c++
代码中介商5 小时前
C++ 类型转换深度解析:static_cast、dynamic_cast、const_cast、reinterpret_cast
开发语言·c++
青小莫5 小时前
C++之string(OJ练习)
开发语言·c++·stl
6Hzlia5 小时前
【Hot 100 刷题计划】 LeetCode 199. 二叉树的右视图 | C++ DFS 逆序遍历
c++·leetcode·深度优先
-Marks-6 小时前
【C++编程】STL简介 --- (是什么 | 版本发展历程 | 六大组件 | 重要性缺陷以及如何学习)
开发语言·c++·学习·stl·stl版本
CoderCodingNo7 小时前
【信奥业余科普】C++ 的奇妙之旅 | 12:程序的交互与加工——数据的输入与算术运算
开发语言·c++
yx868xy7 小时前
Cuda加速直线拟合
c++·cuda