码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 图的遍历 广度优先遍历(爱思创)


    前言:

    这篇文章还是是为了帮助一些

    像我这样的菜鸟

    找到简单的题解

    问题描述:

    读入一个用邻接矩阵存储的无向连通图,输出它的广度(宽度)优先遍历序列。

    输入格式

    第一行一个正整数 n(2≤n≤100),表示图中顶点数。

    接下来是一个 n×nn×n 的邻接矩阵,a[i][j]=1 表示顶点 i 和顶点 j 之间有直接边相连,a[i][j]=0a 表示没有直接边相连。

    保证 i=j时,a[i][j]=0,并且 a[i][j]=a[j][i]。

    输出格式

    输出从顶点 1 开始,对该图进行宽度优先遍历得到的顶点序列,每两个数之间用一个 -分隔。

    思考:如果不是连通图,比如某个顶点 x 孤立在外,即邻接矩阵中的 a[x][j]=0,a[i][x]=0,该如何处理?

    样例输入

    8
    0 1 1 0 0 0 0 0
    1 0 0 1 1 0 0 0
    1 0 0 0 0 0 1 1
    0 1 0 0 0 1 0 0
    0 1 0 0 0 1 0 0
    0 0 0 1 1 0 0 0
    0 0 1 0 0 0 0 1
    0 0 1 0 0 0 1 0

    样例输出

    1-2-3-4-5-7-8-6

    问题提示

    问题解析:

    只需要把上一题的DFS改为BFS即可

    非常简单

    直接上代码了

    图的遍历 深度优先遍历(爱思创)_吾乃狙击神蛐的博客-CSDN博客

    代码BFS部分: 

    1. queue<int> q;
    2. void bfs(int x)
    3. {
    4. vis[x]=1;
    5. q.push(x);//入队
    6. while(!q.empty())//判空
    7. {
    8. int cur=q.front();//存储队首
    9. for(int i=1;i<=n*2;i++)
    10. {
    11. if(g[cur][i]==1 && vis[i]==0)
    12. {
    13. q.push(i);
    14. vis[i]=1;//打标记
    15. }
    16. }
    17. if(q.front()!=1) cout<<"-"<front();//输出答案
    18. q.pop();//别忘了出队
    19. }
    20. cout<
    21. return ;
    22. }

    完整代码:

    1. #include
    2. using namespace std;
    3. int g[1001][1001],vis[1001];
    4. int n,m;
    5. queue<int> q;
    6. void bfs(int x)
    7. {
    8. vis[x]=1;
    9. q.push(x);
    10. while(!q.empty())
    11. {
    12. int cur=q.front();
    13. for(int i=1;i<=n*2;i++)
    14. {
    15. if(g[cur][i]==1 && vis[i]==0)
    16. {
    17. q.push(i);
    18. vis[i]=1;
    19. }
    20. }
    21. if(q.front()!=1) cout<<"-"<front();
    22. q.pop();
    23. }
    24. cout<
    25. return ;
    26. }
    27. int main()
    28. {
    29. cin>>n;
    30. int x,y;
    31. for(int j = 1 ; j <= n ;j++)
    32. {
    33. for(int i = 1 ; i <= n ;i++)
    34. {
    35. cin>>g[j][i];//模仿上一题输入
    36. }
    37. }
    38. cout<<1;
    39. bfs(1);
    40. return 0;
    41. }

    如果BFS不熟可以看我之前的文章

    c++二叉树BFS3题解(爱思创)_吾乃狙击神蛐的博客-CSDN博客

    AC 

  • 相关阅读:
    UTONMOS:布局的“元宇宙”未来产生哪些影响?
    分布式调度器xxl-job
    【故事证明和概率公理】
    11 传输层协议
    Redis入门到实战(四、原理篇)RESP协议
    Java构建树结构的公共方法
    webpack之hot热更新
    Promise从入门到精通(第4章 async 和 await)
    k8s高可用集群(一)
    高等数学(第七版)同济大学 习题7-1 个人解答
  • 原文地址:https://blog.csdn.net/HackerQY/article/details/126002124
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号