当前位置: 首页 > news >正文

dfs深度优先搜索—邻接矩阵 + 邻接矩阵-递归版 + 邻接表

邻接矩阵

#include<iostream>
#include<stack>
using namespace std;

const int N = 1e2 + 10;
//n个顶点,m条边
int n, m;
//邻接矩阵
int g[N][N];
//标记数组
bool vis[N];//vis[2]=1/0  代表2号点   1-被标记  0-没被标记

//dfs-深度优先搜索
void dfs(int s/*搜索的起点*/) {
	stack<int> stk;
	//1.起点入栈,入栈即标记(防止重复搜索)
	stk.push(s);  vis[s] = 1;
	while (!stk.empty()) {
		//2.搜索栈顶元素并弹栈
		int v = stk.top();  stk.pop();
		cout << v << " ";
		//3.找到v的邻接点,沿着邻接点进行深度搜索
		for (int i = 1; i <= n; i++) {//7后入栈先出栈
      //for (int i = n; i >= 1; i--)//2后入栈先出栈
			if (!vis[i] && g[v][i] == 1) {//i没有走过且i是v的邻接点
				//入栈+标记
				stk.push(i);  vis[i] = 1;
			}
		}
	}
}
int main() {
	cin >> n >> m;
	for (int i = 1; i <= m; i++) {
		int u, v; cin >> u >> v;
		g[u][v] = g[v][u] = 1;
	}
	int s; cin >> s;
	dfs(s);//从起点s开始深搜
	return 0;
}
/*
输入:
7 6
1 2
2 3
3 4
1 5
5 6
1 7
1*/

 邻接矩阵-递归版

#include<iostream>
#include<stack>
using namespace std;

const int N = 1e2 + 10;
//n个顶点,m条边
int n, m;
//邻接矩阵
int g[N][N];
//标记数组
bool vis[N];//vis[2]=1/0  代表2号点   1-被标记  0-没被标记

//dfs-深度优先搜索
void dfs(int p/*搜索的起点*/) {

	//搜索+标记
	cout << p << " ";   vis[p] = 1;
	//找到当前搜索点p所有邻接点,沿着邻接点继续深搜
	for (int i = 1; i <= n; i++)
		if (!vis[i] && g[p][i] == 1)
			dfs(i);
}
//递归流程:
//      1 2 3 4 5 6 7 
//vis   1 1 1 1 1 1 1
//output: 1 2 3 4 5 6 7
//1. dfs(1)  cout<<1   vis[1]   dfs(2)  dfs(5)  dfs(7) X
//2. dfs(7)  cout<<7   vis[7]   X
//2. dfs(5)  cout<<5   vis[5]   dfs(6)  X
//3. dfs(6)  cout<<6   vis[6]   X
//2. dfs(2)  cout<<2   vis[2]   dfs(3)  X
//3. dfs(3)  cout<<3   vis[3]   dfs(4)  X
//4. dfs(4)  cout<<4   vis[4]   X
//!for循环结束之后才可以继续往下走
int main() {

	cin >> n >> m;

	for (int i = 1; i <= m; i++) {
		int u, v; cin >> u >> v;
		g[u][v] = g[v][u] = 1;
	}

	int s; cin >> s;
	dfs(s);//从起点s开始深搜
	return 0;
}

邻接表

#include<iostream>
#include<vector>
using namespace std;

const int N = 1e4 + 10;
vector<int> g[N];//邻接表存图
bool vis[N];//标记数组-防止重复搜索
int n, m, s;//n-点数  m-边数  s-搜索起点

//正在搜索顶点p
void dfs(int p/*正在搜索的点*/, int depth/*搜索深度*/) {
	//搜索当前点并标记
	cout << depth << " " << p << endl;   vis[p] = 1;
	//沿着当前点的邻接点继续深搜
	for (auto u : g[p]) {//g[p]里面存的每一个元素都是p的邻接点
		if (!vis[u]) {//没有被搜过
			dfs(u, depth + 1);//沿着邻接点u继续深搜
		}
	}
}

int main() {

	cin >> n >> m;
	for (int i = 1; i <= m; i++) {
		int u, v;  cin >> u >> v;
		g[u].push_back(v);  g[v].push_back(u);
	}
	cin >> s;
	dfs(s, 1);
	return 0;
}

相关文章:

  • 基于Flask的茶叶销售数据可视化分析系统设计与实现
  • 一. vue2和vue3的Proxy底层源码详细拆解
  • Kepware的OPC UA配置深入介绍
  • C++ 中将类的定义和实现都放在头文件中的优缺点分析
  • 【20250215】二叉树:94.二叉树的中序遍历
  • 深入理解Elasticsearch集群与分片:原理及配置方案
  • 【硬件设计细节】缓冲驱动器使用注意事项
  • Springboot项目:使用MockMvc测试get和post接口(含单个和多个请求参数场景)
  • Git 本地项目上传 GitHub 全指南(SSH Token 两种上传方式详细讲解)
  • 代码随想录刷题攻略---动态规划---子序列问题1---子序列
  • 计算机视觉+Numpy和OpenCV入门
  • Plaid | 数据库切换历程:从 AWS Aurora MySQL 到 TiDB 的迁移之旅
  • ⚡️《静电刺客的猎杀手册:芯片世界里的“千伏惊魂“》⚡️
  • LeetCodehot 力扣热题100 从前序与中序遍历序列构造二叉树
  • 尚硅谷课程【笔记】——大数据之Hadoop【一】
  • Codeforces Round 1004 (Div. 2)(A-E)
  • HTML、Vue和PHP文件的区别与联系
  • mybatis-lombok工具包介绍
  • 第十五届蓝桥杯嵌入式省赛真题(满分)
  • Android Studio - 解决gradle文件下载失败
  • 习近平举行仪式欢迎巴西总统卢拉访华
  • 第四届长三角国际应急博览会开幕,超3000件前沿装备技术亮相
  • 巴基斯坦全国航班仍持续延误或取消
  • 国际博物馆日中国主会场确定,北京将展“看·见殷商”等展览
  • 上海与世界|环城生态公园带是上海绿色发展新名片
  • 中美经贸高层会谈在日内瓦结束,中国代表团将举行发布会