北航数据结构与程序设计图部分选填题

2024-06-21 12:12

本文主要是介绍北航数据结构与程序设计图部分选填题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、
在这里插入图片描述抓两个关键信息:无向图,邻接表。无向图中,边(vi,vj)要在vi的链表中记录一次,再以(vj,vi)的形式在vj的链表中记录一次。

每个边都要记录两次,则邻接表中边数为2n。


二、

在这里插入图片描述
无向图、邻接矩阵。同上一题,同一条边,(vi,vj)和(vj,vi)都要记录一次。因此是对称矩阵。(注意不要和对角矩阵搞混)


三、
在这里插入图片描述
n个顶点的无向图,边数最多的时候成为完全图。即用排列组合的公式:n(n-1)/ 2 = 8*7/2=28


四、
在这里插入图片描述同一条边(vi,vj)既要算在顶点vi的度数里,又要算在顶点vj的度数里,因此度数等于边数的两倍。


五、
在这里插入图片描述先访问当前结点,然后按照编号大小依次访问与它直接连接的节点。


六、
在这里插入图片描述

无论是无向连通图还是有向连通图,最小生成树都不一定唯一。


七、
在这里插入图片描述
广度优先遍历类似于树的层序遍历,因此是用队列。基本思想是:“父节点进队——父节点出队——其子节点入队——直至栈空”


八、
在这里插入图片描述
这个要从代码的角度考虑,因为期末图不考编程题所以我们记住结论即可:
Prim算法的时间复杂度:O(n²),Kruskal算法的时间复杂度:O(eloge)。


九、
在这里插入图片描述基本概念要记牢哦~


十、
在这里插入图片描述
有向图、邻接矩阵。对于有向图来说,第i 的所有非0非无穷大的元素个数等于其入度。

对于无向图来说,第i行第i列的所有非0非无穷大的元素个数等于其度数。


十一、
在这里插入图片描述
稀疏图选邻接表更节省空间。


十二、
在这里插入图片描述
蛮有意思,去掉任意一条边,都是生成树而且是最小生成树,一共有n条边,则有n个生成树。


十三、
在这里插入图片描述①T={V1},U={V2,V3,V4,V5,V6},T中元素和U中元素的连线有9,10,16,最小边为9,因此v4加入T;
②T={V1,V4},U={V2,V3,V5,V6},T和U连线中有2,10,16,最小边为2,V3加入T
③T={V1,V4,V3},U={V2,V5,V6},T和U中连线有16,11,14,18,最小边11,V2加入T
④T={V1,V4,V3,V2},U={V5,V6},T和U中连线有18,14,6,5,最小边5,V6加入T
⑤T={V1,V4,V3,V2,V6},U={V5},T和U中连线有1,6,14,18,最小边1,加入。
⑥至此T中包含了所有结点,因此最后一个加的边权值为1.


十四、
在这里插入图片描述
选1,选2,选5,选6不行,成环,选9,选10不行成环,选11,此时包含了所有顶点,因此最后一个为11.


十五、
在这里插入图片描述

注意注意:是非连通,最多28条。完全图顶点和边计算公式为n(n-1)/2,也是边数最多情况,但是,如果是8个顶点,28条边,就是完全图了,就连通了,所以至少有9个顶点才可以。


十六、
在这里插入图片描述拓扑序列生成步骤:

  1. 在有向图中选一个没有前驱的顶点并输出
  2. 在图中删除该顶点和所有以它为尾的弧
  3. 重复上述步骤,直至全部顶点均已输出,或当图中不存在无前驱的顶点为止。

我们发现只有V3没有前驱,则先输出V3,则<v3,v1>、<v3,v4>删除。
然后V1没有前驱,则输出V1,<v1,v2>、<v1,v4>删除。
接下来V4没有前驱,输出V4,<v4,v5>删除
V5无前驱,V5输出,<v5,v2>,<v5,v6>删除
V2无前驱,V2输出,<V2,V6>删除
最后剩了一个节点V6,v6输出。

这篇关于北航数据结构与程序设计图部分选填题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1081187

相关文章

SpringBoot实现微信小程序支付功能

《SpringBoot实现微信小程序支付功能》小程序支付功能已成为众多应用的核心需求之一,本文主要介绍了SpringBoot实现微信小程序支付功能,文中通过示例代码介绍的非常详细,对大家的学习或者工作... 目录一、引言二、准备工作(一)微信支付商户平台配置(二)Spring Boot项目搭建(三)配置文件

C#数据结构之字符串(string)详解

《C#数据结构之字符串(string)详解》:本文主要介绍C#数据结构之字符串(string),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录转义字符序列字符串的创建字符串的声明null字符串与空字符串重复单字符字符串的构造字符串的属性和常用方法属性常用方法总结摘

Mysql删除几亿条数据表中的部分数据的方法实现

《Mysql删除几亿条数据表中的部分数据的方法实现》在MySQL中删除一个大表中的数据时,需要特别注意操作的性能和对系统的影响,本文主要介绍了Mysql删除几亿条数据表中的部分数据的方法实现,具有一定... 目录1、需求2、方案1. 使用 DELETE 语句分批删除2. 使用 INPLACE ALTER T

如何用java对接微信小程序下单后的发货接口

《如何用java对接微信小程序下单后的发货接口》:本文主要介绍在微信小程序后台实现发货通知的步骤,包括获取Access_token、使用RestTemplate调用发货接口、处理AccessTok... 目录配置参数 调用代码获取Access_token调用发货的接口类注意点总结配置参数 首先需要获取Ac

基于Python开发PDF转Doc格式小程序

《基于Python开发PDF转Doc格式小程序》这篇文章主要为大家详细介绍了如何基于Python开发PDF转Doc格式小程序,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 用python实现PDF转Doc格式小程序以下是一个使用Python实现PDF转DOC格式的GUI程序,采用T

将java程序打包成可执行文件的实现方式

《将java程序打包成可执行文件的实现方式》本文介绍了将Java程序打包成可执行文件的三种方法:手动打包(将编译后的代码及JRE运行环境一起打包),使用第三方打包工具(如Launch4j)和JDK自带... 目录1.问题提出2.如何将Java程序打包成可执行文件2.1将编译后的代码及jre运行环境一起打包2

在不同系统间迁移Python程序的方法与教程

《在不同系统间迁移Python程序的方法与教程》本文介绍了几种将Windows上编写的Python程序迁移到Linux服务器上的方法,包括使用虚拟环境和依赖冻结、容器化技术(如Docker)、使用An... 目录使用虚拟环境和依赖冻结1. 创建虚拟环境2. 冻结依赖使用容器化技术(如 docker)1. 创

Go语言中三种容器类型的数据结构详解

《Go语言中三种容器类型的数据结构详解》在Go语言中,有三种主要的容器类型用于存储和操作集合数据:本文主要介绍三者的使用与区别,感兴趣的小伙伴可以跟随小编一起学习一下... 目录基本概念1. 数组(Array)2. 切片(Slice)3. 映射(Map)对比总结注意事项基本概念在 Go 语言中,有三种主要

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟&nbsp;开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚&nbsp;第一站:海量资源,应有尽有 走进“智听

【数据结构】——原来排序算法搞懂这些就行,轻松拿捏

前言:快速排序的实现最重要的是找基准值,下面让我们来了解如何实现找基准值 基准值的注释:在快排的过程中,每一次我们要取一个元素作为枢纽值,以这个数字来将序列划分为两部分。 在此我们采用三数取中法,也就是取左端、中间、右端三个数,然后进行排序,将中间数作为枢纽值。 快速排序实现主框架: //快速排序 void QuickSort(int* arr, int left, int rig