news 2026/3/15 2:17:42

根据邻接矩阵对图进行深度广度优先搜索

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
根据邻接矩阵对图进行深度广度优先搜索

题目:以邻接矩阵给出一张以整数编号为顶点的图,其中0为不相连,1为相连。按深度和广度优先进行遍历,输出全部结果。要求遍历时优先较小的顶点。

#include <deque> #include <iostream> #include <stack> #include <vector> #include <algorithm> using namespace std; class Graph { private: int V; vector<vector<int>> adj; public: Graph(int vertices, int** arr): V(vertices) { adj.resize(V); for (int i = 0; i < V; i++) { for (int j = 0; j < V; j++) { if (arr[i][j] == 1) { adj[i].push_back(j); } } sort(adj[i].begin(), adj[i].end()); } } void DFS(int start) { stack<int> s; vector<bool> visited(V, false); //第一个参数是元素个数,第二个是元素的初始值 s.push(start); while (!s.empty()) { int temp = s.top(); s.pop(); if (!visited[temp]) { visited[temp] = true; cout << temp << " "; } for (auto it = adj[temp].rbegin(); it != adj[temp].rend(); it++) { //利用反向迭代器得到里面的数据 if (!visited[*it]) { s.push(*it);//这里必须要用*it是为了解引用迭代器,否则it就只是个位置指示器,而不是一个具体的数据 } } } cout << endl; } void WFS(int start) {//统一在入队的时候进行让visited数组为true deque<int> q; vector<bool> visited(V, false); //初始节点入队并标记 q.push_back(start); visited[start] = true; while (!q.empty()) { int v = q.front(); q.pop_front(); //if(!visited[v]){ cout << v << " "; //这里直接输出,不要再次检查 //} for (auto it = adj[v].begin(); it != adj[v].end(); it++) { if (!visited[*it]) { q.push_back(*it); visited[*it] = true; } } } cout << endl; } //这里需要注意的是,DFS使用的是栈,所以在出栈的时候标记访问,因为是所有元素一下全部进栈 //而WFS用的是队列,没访问完一个元素将他弹出的时候就访问他的neighbor并把他们入队 //所以这里就要求的每次入队的时候就标记访问 }; int main() { int size; cin >> size; int** maze = new int* [size]; for (int i = 0; i < size; i++) { maze[i] = new int[size]; } for (int i = 0; i < size; i++) { for (int j = 0; j < size; j++) { int a; cin >> a; maze[i][j] = a; } } Graph graph(size, maze); cout << "DFS" << endl; for (int i = 0; i < size; i++) { graph.DFS(i); } cout << "WFS" << endl; for (int i = 0; i < size; i++) { graph.WFS(i); } for (int i = 0; i < size; i++) { delete[] maze[i]; } delete[] maze; }

需要注意两种遍历方法的不同。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/15 0:47:26

LobeChat能否集成极光预报?天文摄影最佳时机推荐

LobeChat能否集成极光预报&#xff1f;天文摄影最佳时机推荐 在北欧的冬夜&#xff0c;一位摄影师站在冰岛荒原上&#xff0c;寒风刺骨&#xff0c;相机三脚架早已冻得发硬。他打开手机&#xff0c;焦急地翻看多个App&#xff1a;一个查KP指数&#xff0c;一个看云量图&#xf…

作者头像 李华
网站建设 2026/3/9 10:29:29

百度网盘解析工具:3分钟解决下载限速难题

百度网盘解析工具&#xff1a;3分钟解决下载限速难题 【免费下载链接】baidu-wangpan-parse 获取百度网盘分享文件的下载地址 项目地址: https://gitcode.com/gh_mirrors/ba/baidu-wangpan-parse 还在为百度网盘的下载速度发愁吗&#xff1f;每次看到几十KB的下载进度&a…

作者头像 李华
网站建设 2026/3/10 15:27:12

3分钟突破原神60帧瓶颈:内存级性能优化实战指南

3分钟突破原神60帧瓶颈&#xff1a;内存级性能优化实战指南 【免费下载链接】genshin-fps-unlock unlocks the 60 fps cap 项目地址: https://gitcode.com/gh_mirrors/ge/genshin-fps-unlock 原神作为当前最受欢迎的开放世界游戏之一&#xff0c;其精美的画面和流畅的操…

作者头像 李华
网站建设 2026/3/11 17:17:59

7天性能翻倍:Axolotl推理缓存优化实战全解析

7天性能翻倍&#xff1a;Axolotl推理缓存优化实战全解析 【免费下载链接】axolotl 项目地址: https://gitcode.com/GitHub_Trending/ax/axolotl 你是否遇到过这样的场景&#xff1a;在部署大语言模型服务时&#xff0c;相同系统提示词被反复计算&#xff0c;GPU资源在重…

作者头像 李华
网站建设 2026/3/13 18:20:44

LobeChat能否用于编写Helm Chart?K8s应用打包利器

LobeChat 与 Helm Chart&#xff1a;云原生 AI 应用的标准化打包之路 在企业级 AI 应用加速落地的今天&#xff0c;一个现实问题摆在架构师面前&#xff1a;如何让像 LobeChat 这样的现代化聊天界面&#xff0c;既能保持灵活可定制的特性&#xff0c;又能被快速、安全、一致地部…

作者头像 李华
网站建设 2026/3/13 14:11:38

情书写作助手:LobeChat帮你表达爱意

情书写作助手&#xff1a;LobeChat帮你表达爱意 在数字时代&#xff0c;我们比以往任何时候都更擅长发送消息——却更难说出真心话。一条“早安”可以自动回复&#xff0c;但一句“我爱你”却常常卡在指尖。尤其是面对深爱的人&#xff0c;越是想写一封真挚动人的情书&#xff…

作者头像 李华