DS期末复习卷(七)

news2024/11/29 4:36:48

一、选择题(30分)

1.设某无向图有n个顶点,则该无向图的邻接表中有( B )个表头结点。
(A) 2n (B) n ( C) n/2 (D) n(n-1)

n
表头结点数=顶点数

2.设无向图G中有n个顶点,则该无向图的最小生成树上有( B )条边。
(A) n (B) n-1 ( C) 2n (D) 2n-1

一个顶点和其他的n-1个顶点相连,共n-1条边

3.设一组初始记录关键字序列为(60,80,55,40,42,85),则以第一个关键字60为基准而得到的一趟快速排序结果是( C )。
(A) 40,42,60,55,80,85 (B) 42,40,55,60,85,80
( C) 42,40,55,60,80,85 (D) 42,40,60,85,55,80

60 80 55 40 42 85
42 60 55 40 80 85
42 40 60 55 80 85
42 40 55 60 80 85

4.( B )二叉排序树可以得到一个从小到大的有序序列。
(A) 先序遍历 (B) 中序遍历 © 后序遍历 (D) 层次遍历

左中右

5.设按照从上到下、从左到右的顺序从1开始对完全二叉树进行顺序编号,则编号为i结点的左孩子结点的编号为( B )。
(A) 2i+1 (B) 2i © i/2 (D) 2i-1

6.程序段s=i=0;do {i=i+1; s=s+i;}while(i<=n);的时间复杂度为( A )。
在这里插入图片描述

7.设带有头结点的单向循环链表的头指针变量为head,则其判空条件是( C )。
(A) head = =0 (B) head->next= =0
© head->next==head (D) head!=0

单向循环链表为空 那么头结点的下一个结点指向头结点本身。

8.设某棵二叉树的高度为10,则该二叉树上叶子结点最多有( C)。
(A) 20 (B) 256 ( C ) 512 (D) 1024

二叉树的结点个数最多有2^(h-1)

9.设一组初始记录关键字序列为(13,18,24,35,47,50,62,83,90,115,134),则利用二分法查找关键字90需要比较的关键字个数为( B)。
(A) 1 (B) 2 © 3 (D) 4

这里是引用

10.设指针变量top指向当前链式栈的栈顶,则删除栈顶元素的操作序列为( D )。
(A) top=top+1; (B) top=top-1;
© top->next=top; (D) top=top->next;

直接将top指针指向top的下一个元素。

二、判断题(20分)

1.不论是入队列操作还是入栈操作,在顺序存储结构上都需要考虑“溢出”情况。 ()

2.当向二叉排序树中插入一个结点,则该结点一定成为叶子结点。 ()

3.设某堆中有n个结点,则在该堆中插入一个新结点的时间复杂度为O(log2n)。 ( )

4,完全二叉树中的叶子结点只可能在最后两层中出现。 ()

5.哈夫曼树中没有度数为1的结点。 ( )

对。
给定N个权值作为N个叶子结点,构造一棵二叉树,若该树的带权路径长度达到最小,称这样的二叉树为最优二叉树,也称为哈夫曼树(Huffman Tree)。哈夫曼树是带权路径长度最短的树,权值较大的结点离根较近。

6,对连通图进行深度优先遍历可以访问到该图中的所有顶点。 ()


连通图可以 非连通图不可以

7.先序遍历一棵二叉排序树得到的结点序列不一定是有序的序列。 ()

对 中序遍历才是

8.由树转化成二叉树,该二叉树的右子树不一定为空。 ( )

错 右子树一定为空 因为树根结点没有右兄弟

9.线性表中的所有元素都有一个前驱元素和后继元素。()

除了开头和结尾

10.带权无向图的最小生成树是唯一的。 ( )

错 最小生成树不一定是唯一的

三、填空题(30分)

1.设指针变量p指向双向链表中的结点A,指针变量s指向被插入的结点X,则在结点A的后面插入结点X的操作序列为______;s->right=p->right;______=s; p->right->left=s; (设结点中的两个指针域分别为left和right)。

s->left=p
p->right

2.设完全有向图中有n个顶点,则该完全有向图中共有_____条有向条;设完全无向图中有n个顶点,则该完全无向图中共有_____条无向边。

n(n-1)
n(n-1)/2

3.设关键字序列为(K,K2,…,Kn),则用筛选法建初始堆必须从第___个元素开始进行筛选。

“…我们称这个自堆至叶子的调整过程为筛选。从一个无序序列建堆过程就是一个反复筛选的过程。若将此序列看成是一个完全二叉树,则最后一个非终端结点是第[n/2]个元素,由此筛选只需从第[n/2]个元素开始” 出自严蔚敏《数据结构》280页。

4.解决散列表冲突的两种方法是__________
和______。

开放定址法
链地址法

5.设一棵三叉树中有50个度数为0的结点,21个度数为2的结点,则该二叉树中度数为3的结点数有___个。

由2叉树的性质引申出,对于任何一颗树T,如果其终端结点树为n0 度为的结点数为ni,则n0=1+n2+2n3+…+(i-1)ni.
n0=1+n2+2n3
代入 N0=50,N2=21
得 N3=14

6.高度为h的完全二叉树中最少有_____个结点,最多有_____个结点。

2^(h-1)
2 ^h -1

7.设有一组初始关键字序列为(24,35,12,27,18,26),则第3趟直接插入排序结束后的结果的是_____

在这里插入图片描述

8.设有一组初始关键字序列为(24,35,12,27,18,26),则第3趟简单选择排序结束后的结果的是_____

选择排序基本思想:
在长度为N的无序数组中,第一次遍历n-1个数,找到最小的数值与第一个元素交换;
第二次遍历n-2个数,找到最小的数值与第二个元素交换;
。。。
第n-1次遍历,找到最小的数值与第n-1个元素交换,排序完成。
在这里插入图片描述

9.设一棵二叉树的前序序列为ABC,则有_____
种不同的二叉树可以得到这种序列。

5
在这里插入图片描述
10、在这里插入图片描述
i<j&&r[[i].key<x.key
r[i]=x

四、算法设计题(20分)

1.设计在链式结构上实现简单选择排序算法。

排序算法的简单介绍:从序列的第一个数开始到最后一个数,找当前序列中最小的数与当前位置的数进行交换。

void simpleselectsorlklist(lklist *&head)
{
  lklist *p,*q,*s;  
  int min,t;
  if(head==0 ||head->next==0) return;
  for(q=head; q!=0;q=q->next)
  {
    min=q->data; 
    s=q;
    for(p=q->next; p!=0;p=p->next) 
    	if(min>p->data){min=p->data; s=p;}
    if(s!=q){
    		t=s->data; 
    		s->data=q->data; 
    		q->data=t;
    	}
  }
}

2.设计在顺序存储结构上实现求子串算法。

void substring(char s[ ], long start, long count, char t[ ])
{
  long i,j,length=strlen(s);
  if (start<1 || start>length) printf("The copy position is wrong");
  else if (start+count-1>length) printf("Too characters to be copied");
else { for(i=start-1,j=0; i<start+count-1;i++,j++) t[j]=s[i]; t[j]= '\0';}
}

3.设计求结点在二叉排序树中层次的算法。

int lev = 0;
typedef struct node { 
	int key; 
	struct node* lchild, * rchild; 
	}bitree;
void level(bitree* bt, int x)
{
	if (bt != 0)
	{
		lev++; 
		if (bt->key == x) return lev; 
		else if (bt->key > x) 
		level(bt->lchild, x); 
		else level(bt->rchild, x);
	}
}

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

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

相关文章

mysql修改root用户密码

一、记得密码 登录mysql执行以下语句 mysql -u root -p 按回车确认, 如果安装正确且 MySQL 正在运行, 会得到以下响应: 然后输入正确的密码&#xff0c;进入mysql 然后修改密码&#xff1a; mysql> ALTER USER rootlocalhost IDENTIFIED BY 123456; mysql> flush p…

二叉树——路径总和

路径总和 链接 给你二叉树的根节点 root 和一个表示目标和的整数 targetSum 。判断该树中是否存在 根节点到叶子节点 的路径&#xff0c;这条路径上所有节点值相加等于目标和 targetSum 。如果存在&#xff0c;返回 true &#xff1b;否则&#xff0c;返回 false 。 叶子节点…

风光并网对电网电能质量影响的matlab/simulink仿真建模

之前配电网的一个项目&#xff0c;我把其中一部分分享给大家&#xff0c;电能质量影响这部分&#xff0c;我在模型中主要体现的就是不同容量的光伏、风电接入&#xff0c;对并网点的电压影响情况。 前言 考虑到我国的地理因素以及气候影响问题&#xff0c;我国的风电开发相应的…

华为分布式存储(FusionStorage)

Server SAN SAN&#xff1a;存储区域网络 IP SAN&#xff1a;以太网交换机和普通网线连接的存储&#xff0c;交换机之间做堆叠FC SAN&#xff1a;FC&#xff08;光纤&#xff09;交换机和光纤连接的存储&#xff0c;交换机之间做级联Server SAN&#xff1a;可以使用以太网交换机…

75岁彪马再发NFT 复活美洲狮IP

在“运动品牌Web3”的潮流里&#xff0c;彪马&#xff08;PUMA&#xff09;绝对算是发烧友级别。2月22日&#xff0c;这家德国服装品牌的新NFT又来了&#xff0c;总量10000个Super PUMA NFT中&#xff0c;将有4000个以0.15 ETH&#xff08;约为255美元&#xff09;价格正式公售…

C++设计模式(18)——模板方法模式

亦称&#xff1a; Template Method 意图 模板方法模式是一种行为设计模式&#xff0c; 它在超类中定义了一个算法的框架&#xff0c; 允许子类在不修改结构的情况下重写算法的特定步骤。 问题 假如你正在开发一款分析公司文档的数据挖掘程序。 用户需要向程序输入各种格式…

ICRA 2023 | 首个联合暗光增强和深度估计的自监督方法STEPS

原文链接&#xff1a;https://www.techbeat.net/article-info?id4629 作者&#xff1a;郑宇鹏 本文中&#xff0c;我们提出了STEPS&#xff0c;第一个自监督框架来联合学习图像增强和夜间深度估计的方法。它可以同时训练图像增强网络和深度估计网络&#xff0c;并利用了图像增…

【JAVA程序设计】(C00103)基于Springboot+Thymeleaf智能分类的相册管理系统——有文档

基于SpringbootThymeleaf智能分类的相册管理系统——有文档项目简介项目获取开发环境项目技术运行截图项目简介 基于SpringbootThymeleaf智能分类的相册管理系统共分为二个角色&#xff1a;系统管理员、用户 管理员角色包含以下功能&#xff1a; 登录、用户管理&#xff08;增…

LeetCode-131. 分割回文串

目录题目思路回溯题目来源 131. 分割回文串 题目思路 切割问题类似组合问题。 例如对于字符串abcdef&#xff1a; 组合问题&#xff1a;选取一个a之后&#xff0c;在bcdef中再去选取第二个&#xff0c;选取b之后在cdef中再选取第三个…。切割问题&#xff1a;切割一个a之后&…

现在的00后,实在是太卷了

现在的小年轻真的卷得过分了。前段时间我们公司来了个00年的&#xff0c;工作没两年&#xff0c;跳槽到我们公司起薪18K&#xff0c;都快接近我了。后来才知道人家是个卷王&#xff0c;从早干到晚就差搬张床到工位睡觉了。 最近和他聊了一次天&#xff0c;原来这位小老弟家里条…

ES mapping 详解

nested 类型&#xff1f;&#xff1f;&#xff1f; _all _routing; ES-mapping Elasticsearch根据业务创建映射mapping结构分析&#xff1a;keyword和text&#xff08;一&#xff09;_elasticsearch keyword mapping_周全全的博客-CSDN博客 0.Mapping样例 {"mapping…

【微信小程序】--JSON 配置文件作用(三)

&#x1f48c; 所属专栏&#xff1a;【微信小程序开发教程】 &#x1f600; 作  者&#xff1a;我是夜阑的狗&#x1f436; &#x1f680; 个人简介&#xff1a;一个正在努力学技术的CV工程师&#xff0c;专注基础和实战分享 &#xff0c;欢迎咨询&#xff01; &#…

【Vue源码解析】Vue虚拟dom和diff算法

Vue虚拟dom和diff算法1. 简介2. 搭建环境1. 安装snabbdom2. 安装webpack5并配置3、函数3.1 虚拟节点vnode的属性3.2 使用h函数 创建虚拟节点3.3 使用patch函数 将虚拟节点上DOM树3.4 h函数嵌套使用&#xff0c;得到虚拟DOM树&#xff08;重要&#xff09;3.5 patchVnode函数3.6…

Mac 上搭建 iOS WebDriverAgent 环境

文章目录Mac环境搭建配置 Xcode 生成 WDA常见问题brew 安装失败Mac环境搭建 macOS 系统电脑&#xff1a;12.6.2 Xcode&#xff1a;14.0.1&#xff08;xcodebuild -version&#xff09; appium Desktop&#xff1a;1.21.0 (下载链接) Appium Desktop 1.22.0 &#xff0c;从该版…

Redis 高级数据类型

文章目录一、Bitmaps&#xff1a;属性状态统计二、HyperLogLog&#xff1a;基数统计三、GEO&#xff1a;地理位置信息计算提示&#xff1a;以下是本篇文章正文内容&#xff0c;Redis系列学习将会持续更新 一、Bitmaps&#xff1a;属性状态统计 Bitmaps类型&#xff1a; 统计一…

数据结构:循环队列的实现(leetcode622.设计循环队列)

目录 一.循环队列简单介绍 二.用静态数组实现循环队列 1.数组循环队列结构设计 2.数组循环队列的堆区内存申请接口 3.数据出队和入队的接口实现 4.其他操作接口 5.数组循环队列的实现代码总览 三.静态单向循环链表实现循环队列 1.链表循环队列的结构设计 2.创建静…

Nginx第二讲

目录 二、Nginx02 2.1 keepalived和heartbeat介绍 2.1.1 两者的介绍 2.1.2 keepalived简介 2.1.3 VRRP协议与工作原理 2.1.4 Keepalvied的工作原理 2.2 安装环境及keepalived 2.3 启动与验证keepalived 2.4 keepalived测试 2.4.1 环境准备 2.4.2 配置keepalived 2.…

守护最后一道防线:Coremail邮件安全网关推出邮件召回功能

根据Coremail邮件安全大数据中心2022年Q4季报显示&#xff0c;2021年CAC识别钓鱼邮件1.81亿&#xff0c;2022年上升至2.25亿&#xff0c;增幅高达24.1%。 这表明2022年平均每天有61万7088封钓鱼邮件被接收及发出&#xff0c;企业用户面临潜在经济损失不可估量。 尤其是活跃至今…

Linux中安装JDK

Linux中安装JDK一 、下载JDK包1、下载网址2、往下翻&#xff0c;找到 java83、继续往下翻找到要下载的版本 64位linux版本二 上传jdk安装包三 开始安装整体过程1、解压文件2、查看解压文件3、进入解压文件夹确认4、配置环境变量5、重新加载环境变量6、确认安装成功一 、下载JDK…

Leetcode11. 盛最多水的容器

一、题目描述&#xff1a; 给定一个长度为 nnn 的整数数组 heightheightheight 。有 nnn 条垂线&#xff0c;第 iii 条线的两个端点是 (i,0)(i, 0)(i,0) 和 (i,height[i])(i, height[i])(i,height[i]) 。 找出其中的两条线&#xff0c;使得它们与 xxx 轴共同构成的容器可以容…