【数据结构】填空集

  1. 基本术语

  2. 顺序队列在实现的时候,通常将数组看成是一个首尾相连的循环队列,这样做的目的是为避免产生(溢出)现象

  3. 数组q[M](M等于6)存储一个循环队,first和last分别指向首尾指针。已知first=2,last=5。当从队列中删除一个元素,再插入两个元素后,first=(3),last=(1)

  • 在循环队列中,当删除一个元素时,首指针first会向前移动一位。因此删除一个元素后,first从2变成了3。接着,当插入两个元素时,尾指针last会向前移动两位。
  • 由于队列是循环的,所以当last从5增加到6(即M的值)时,它会回到数组的开始位置,也就是0。再插入一个元素后,last会从0变成1。所以最终first=3和last=1是符合循环队列操作规则的。
  1. 已知一棵完全二叉树的第5层(设根为第1层)有8个叶结点,则该完全二叉树的结点个数最多是(47)

  2. 若以{4,5,6,7,8}作为叶子结点的权值构造哈夫曼树,则其带权路径长度是(69)

  • 28 + 3 4 + 35 + 26 + 2*7 = 69
  1. 逻辑结构的划分

  2. 为了解决队列的假溢出现象,应采用(循环)队列

  3. (结构)是指数据元素之间的关系

  4. 在有n个元素的顺序表中的任意位置插入一个元素所需移动元素的平均次数为(n/2)

  5. 在有n个元素的顺序表中删除任意一个元素所需移动元素的平均次数为 (n-1) / 2

  6. (数据结构)是指相互间存在一种或多种特定关系的数据元素的集合

  7. (数据元素)是数据的基本单位,(数据项)是数据的不可分割最小单位。其中:前者在计算机中通常作为一个整体进行考虑和处理,它可以由一个或多个后者组成

相关推荐
gumichef7 小时前
算法的时间复杂度和空间复杂度
数据结构
cpp_25017 小时前
P1832 A+B Problem(再升级)
数据结构·c++·算法·动态规划·题解·洛谷·背包dp
꧁细听勿语情꧂8 小时前
合并两个有序表、判断链表的回文结构、相交链表、环的链表一和二
c语言·开发语言·数据结构·算法
大肥羊学校懒羊羊8 小时前
完数与盈数的计算题解
数据结构·c++·算法
无限进步_10 小时前
C++ 继承机制完全解析:从基础原理到菱形继承问题
java·开发语言·数据结构·c++·vscode·后端·算法
不知名的忻10 小时前
并查集(QuickUnion)
java·数据结构·算法·并查集
数智化精益手记局11 小时前
仓库安灯管理系统的异常响应机制:破解仓库安灯管理系统的跨部门协同难题
大数据·数据结构·人工智能·制造·精益工程
田梓燊11 小时前
力扣:138.随机链表的复制
算法·leetcode·链表
小张成长计划..11 小时前
【C++】25:哈希表的实现
数据结构·哈希算法·散列表
米啦啦.11 小时前
B-树,,
数据结构·b树·b-树