【数据结构】——图的相关习题

news2024/9/28 19:19:40

目录

  • 一、选择填空判断题
    • 题1
    • 题2
    • 题3
  • 二、应用题
    • 题1

一、选择填空判断题

题1

1、无向图G=(V,E),其中:V={a,b,c,d,e,f},E={(a,b),(a,c),(a,e),(b,e),(c,f),(f,d),(e,d)},以顶点a为源点对该图进行深度优先遍历,得到的顶点序列正确的是()。
A、a,b,e,c,d,f
B、a,c,f,e,b,d
C、a,e,b,c,f,d
D、a,e,d,f,c,b

解析:(D)
如下可画出该无向图:
在这里插入图片描述
图的深度优先搜索(DFS)【类似树的先序遍历,先访问结点,然后递归向外层结点遍历,尽可能深地搜索一个图,都采用回溯算法】。
DFS算法是一个递归过程,其中需借助栈完成操作。首先选取图中某一顶点vi,访问后,任意选取一个与vi邻接的顶点,且该顶点未被访问,……,继续重复该过程,直到图中所有与vi连通的顶点都被访问到;若还有顶点未被访问到,则另外选取一个未被访问的顶点再次作为起始点,重复以上步骤,继续直至图中所有结点被访问。

以顶点a为源点对该图进行深度优先遍历,然后选择与a邻接的任一顶点,由于与a邻接的顶点有b,c,e,可有以下三种访问序列{a,b,……}或{a,c,……}或{a,e,……},
在这里插入图片描述
然后,选择访问顶点d,也可以选择还未被访问的顶点。由于先前选择访问的序列是{a,d},此时访问与顶点d相邻的顶点f,得到序列{a,d,f};再访问与顶点f相邻的顶点c,得到序列{a,d,f,c};由于此时与c邻接的顶点a和f都被访问过,回退到f,继续检查d,与d邻接的顶点也被访问过,……,最后直到顶点d还未被访问,访问它,可得到序列{a,e,d,f,c,b}。

题2

2、如下所示的图进行从顶点1开始的广度优先搜索遍历,可得到的顶点访问序列为()。
A、1,3,2,4,5,6,7
B、1,2,4,3,5,6,7
C、1,2,3,4,5,7,6
D、2,5,1,4,7,3,6

在这里插入图片描述
解析:(B)
图的广度优先搜索(BFS)【类似树的层序遍历,一层一层向外遍历】。
首先选取一个起始点顶点vi,访问后将其入队并标记为已访问(使用队列用于避免重复访问,存放已经访问过的各邻接顶点);当队列不为空时检查出队顶点的所有邻接顶点,访问未被访问的邻接顶点并将其入队,……,继续重复该过程,直到图中所有与vi连通的顶点都被访问到;当队列为空时跳出循环,则此时遍历完成。

以顶点1为源点对该图进行广度优先遍历,选择与其邻接的所有顶点进行访问,有2和3,可得序列{1,2,3}或{1,3,2};然后,再访问与2和3邻接的其他顶点,直到所有顶点被访问。例如,选择访问顶点2,然后访问与顶点2邻接的4;此时访问顶点4的邻接顶点,由于顶点2已经被访问,可选择访问顶点3和顶点5和顶点6,选择顶点3,此时的序列为{1,2,4,3};再访问与顶点4邻接的顶点5和6,序列为{1,2,4,3,5,6};最后还有顶点7还未访问,可得序列{1,2,4,3,5,6,7}。

题3

3、具有n个顶点的有向完全图有()条边。
A、n(n-1)/2
B、n(n-1)
C、n(n+1)/2
D、n(n+1)

解析:(B)
若一个有向图中,若每个顶点都有互相相反的两条弧连接,则称为有向完全图,在一个含有n个顶点的有向完全图中,共有n(n-1)条弧。

例如,含有4个顶点的有向完全图中,共有n(n-1)=4×3=12条弧,如下:
在这里插入图片描述

二、应用题

题1

题型根据图的邻接表存储结构,画出图以及图的深度/广度优先生成树

1、设G=(V,E)以邻接表存储,如下图所示,画出该图的深度优先生成树和广度优先生成树。

在这里插入图片描述

解:由该邻接表可知,顶点1与2,3,4邻接,顶点2与1,3,4,5邻接,顶点3与1,2,4邻接,顶点4与1,2,3,5邻接,顶点5与2,4邻接,画出该图:在这里插入图片描述
图的深度优先遍历序列步骤:
1、首先访问顶点1,访问后标记已访问过,此时序列为{1};
2、查看单链表1,其第一个未访问的邻接顶点为2,再以顶点2为出发点继续深度遍历,此时序列为{1,2};
3、查看单链表2,顶点1已经访问过,所以其未访问的邻接顶点为3,再以顶点3为出发点继续深度遍历,此时序列为{1,2,3};
4、查看单链表3,顶点1和顶点2已经访问过,所以其未访问的邻接顶点为4,再以顶点4为出发点继续深度遍历,此时序列为{1,2,3,4};
5、查看单链表4,顶点1、顶点2、顶点3已经访问过,所以其未访问的邻接顶点为5,再以顶点5为出发点继续深度遍历,此时序列为{1,2,3,4,5};
6、已经不存在未访问的顶点,遍历完成。

图的广度优先遍历序列步骤:
1、首先访问顶点1,访问后标记已访问过,使其入队,然后删除当前队头结点,此时序列为{1};
2、遍历单链表1,使其未访问的邻接顶点2、3、4入队并标记,此时序列为{1,2,3,4};
3、遍历单链表2,使其未访问的邻接顶点5入队并标记,此时序列为{1,2,3,4,5};
4、已经不存在未访问的顶点,遍历完成。

深度优先生成树:
在这里插入图片描述
广度优先生成树:
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/688106.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Spring Boot 中如何使用 Swagger

在 Spring Boot 中使用 Swagger 介绍 在开发 Web 应用时,API 文档的编写和维护是一项非常重要的工作。Swagger 是一款非常流行的 API 文档工具,可以自动生成 API 文档,并提供一系列的交互式工具,如测试界面、调试界面等&#xf…

在线选座票务系统开发 座位预先选出行更方便

我们平时去影院剧场观看电影演出的时候,去早了要等很久才开始,去晚了好座位都被别人占了,自己只能挤在角落里,影响观感体验。影院剧场在线选座APP小程序系统开发就很好的解决了这一问题,可以满足用户在线订座、在线选座…

【动态规划算法练习】day6

文章目录 一、53. 最大子数组和1.题目简介2.解题思路3.代码4.运行结果 二、918. 环形子数组的最大和1.题目简介2.解题思路3.代码4.运行结果 三、152. 乘积最大子数组1.题目简介2.解题思路3.代码4.运行结果 总结 一、53. 最大子数组和 1.题目简介 53. 最大子数组和 给你一个整…

【Java】Java 纪录类(Record Class)及代码示例

本文仅供学习交流使用! Java Record Class相关文章地址: https://www.liaoxuefeng.com/wiki/1252599548343744/1331429187256353 https://www.baeldung.com/java-record-keyword https://www.developer.com/java/java-record-class/ Java中的记录类是什么…

SSMP整合案例(7) MybatisPlus快速service业务层开发

上文 SSMP整合案例(6) 业务service层逻辑编写我们创建并编写了service业务层代码 但是 这样一个一个去写 确实是有点麻烦 重复性工作 但其实这个已经有人帮我们考虑好了 MP就帮我们做了一个 service快捷开发的方式 我们在项目中的service包下创建一个接口 叫 IBookService 其实…

fscan安装以及使用

windows安装 1.go语言下载。 下载msi版本,直接安装就可以不用配置环境变量,默认是帮你安装配合好的 https://go.dev/dl/ 2.配置go环境 使用默认配置的话,下载速度过慢,导致无法完成编译。故需要配置代理。 在cmd命令行中…

RocketMQ --- 基础篇

一、MQ介绍 1.1、为什么要用MQ 消息队列是一种“先进先出”的数据结构 其应用场景主要包含以下3个方面 1.1.1、应用解耦 系统的耦合性越高,容错性就越低。以电商应用为例,用户创建订单后,如果耦合调用库存系统、物流系统、支付系统&…

Shapley值法介绍及实例计算

Shapley值法介绍及实例计算 为解决多个局中人在合作过程中因利益分配而产生矛盾的问题,属于合作博弈领域。应用 Shapley 值的一大优势是按照成员对联盟的边际贡献率将利益进行分配,即成员 i 所分得的利益等于该成员为他所参与联盟创造的边际利益的平均值。 本文从Shapl…

【裸机开发】EPIT 定时器 —— 按键消抖

实际工程中,不能直接通过延时来消抖 ! 这里我们采用定时器来消抖,这也是内核处理消抖的一种方式。 目录 一、基本原理 1、延时消抖的弊端 2、定时器消抖原理 二、按键消抖实现 1、按键中断 2、定时器中断 三、附加:按键 / 定时器中断初…

熊哥保佑你 计算机组成原理复习

移码是符号位取反 . . Cache——主存地址映像: 全相联:块号字块内地址 直接映射:标记行号字块内地址 组相联:标记组号字块内地址 一个单元一个字节 2路组相联: 全相联: 直接映射: . …

代码随想录算法训练营第四十七天| 198.打家劫舍、 213.打家劫舍II 、 337.打家劫舍III

打家劫舍 题目链接:力扣 确定dp数组(dp table)以及下标的含义 dp[i]:截至到i位置的房屋,最多可以偷窃的金额为dp[i]。确定递推公式 决定dp[i]的关键因素就是第i房间偷还是不偷。如果偷第i房间,那么dp[i] …

Ceph分布式存储系统搭建

目录 安装部署示例 (一)准备环境 1). 设置主机名 2). 关闭防火墙 3).添加sdb磁盘并格式化 4).配置hosts解析文件 5).配置免密登录 6).同步时区 7). 安装 Ceph 包 (二)创建 Ceph 集群 1、 安装ceph-deploy管理工具 2、 …

【C++】STL——string类的基本介绍、string常见的使用、string类的接口说明、string类的容量操作

文章目录 1.C语言的字符串2.C标准库中的string类2.1string类2.2string类的常用接口说明2.3string类对象的容量操作 1.C语言的字符串 在C语言中,字符串被表示为字符数组。C语言中的字符串以’\0’字符(null字符或字符串结束符)结尾&#xff0c…

了解 Splashtop 的多层安全防护措施

随着技术的进步,如何确保数据安全也越来越重要。Splashtop 作为行业领先的远程访问软件供应商,对这一点非常了解。Splashtop 基于信任、客观性、监控和隐私搭建安全框架,致力于保护所有数据交互和用户设备。 了解 Splashtop 安全性的核心 S…

图像色彩增强相关论文阅读-Representative Color Transform for Image Enhancement(ICCV2021)

文章目录 Representative Color Transform for Image EnhancementAbstractIntroductionRelated workMethod实验Conclusion Representative Color Transform for Image Enhancement 作者:Hanul Kim1, Su-Min Choi2, Chang-Su Kim3, Yeong Jun Koh 单位:S…

MySQL调优系列(八)——事务和锁分类

一、事务是什么 事务是逻辑上的一组操作,要么都执行,要么都不执行。 sql语句如下: # 开启事务 START TRANSACTION; # 多条 SQL 语句 SQL1,SQL2... ## 提交事务 COMMIT;二、事务的特性(ACID) 原子性(Atom…

线上商城开发都有哪些方法?费用多少

随着如今网络环境的愈发成熟,人们的消费习惯开始逐渐向线上迁移,为了能满足此种需求,企业商家都开始了线上商城的建设,希望能借助网络的力量促进自身的发展,创造更高的盈利空间,那么如何搭建一个线上商城呢…

Zookeeper 从安装到应用

博主介绍: ✌博主从事应用安全和大数据领域,有8年研发经验,5年面试官经验,Java技术专家✌ Java知识图谱点击链接:体系化学习Java(Java面试专题) 💕💕 感兴趣的同学可以收…

GPIO模拟时序控制外设3——AT24C02

文章目录 前言AT24C02简介引脚介绍器件寻址寻址流程器件地址的组成其他I2C器件的地址组成 通信流程1.完整的传输过程2.初始化管脚3.起始信号4.停止信号5.MCU发送8位数据5.MCU接收应答位6.MCU接收八位数据7.MCU发送应答位 AT24C02写一个字节AT24C02读一个字节实现的效果 总结 前…

如何利用VS打包C++程序

如何将VS开发的C程序打包发给别人使用呢?话不多说,跟随以下步骤即可完成: 打包步骤 一.安装插件1.项目-->扩展-->管理扩展2.搜索-->下载3.下载完毕-->关闭VS4.Modify-->End Tasks(跳过)-->完成 二.配…