以数据结构之——树来体会深度优先搜索【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;
}

运行结果:

输入:

输入+输出:

相关推荐
Xudde.9 小时前
班级作业笔记报告0x04
笔记·学习·安全·web安全·php
晓晓hh9 小时前
JavaSE学习——迭代器
java·开发语言·学习
iFlyCai9 小时前
C语言中的指针
c语言·数据结构·算法
Laurence9 小时前
C++ 引入第三方库(一):直接引入源文件
开发语言·c++·第三方库·添加·添加库·添加包·源文件
查古穆9 小时前
栈-有效的括号
java·数据结构·算法
汀、人工智能9 小时前
16 - 高级特性
数据结构·算法·数据库架构·图论·16 - 高级特性
421!10 小时前
GPIO工作原理以及核心
开发语言·单片机·嵌入式硬件·学习
蒸汽求职10 小时前
机器人软件工程(Robotics SDE):特斯拉Optimus落地引发的嵌入式C++与感知算法人才抢夺战
大数据·c++·算法·职场和发展·机器人·求职招聘·ai-native
charlee4410 小时前
最小二乘问题详解17:SFM仿真数据生成
c++·计算机视觉·sfm·数字摄影测量·无人机航测
Tanecious.10 小时前
蓝桥杯备赛:Day4-P9749 公路
c++·蓝桥杯