【数据结构】填空集

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

相关推荐
努力努力再努力wz2 小时前
【Linux网络系列】:TCP 的秩序与策略:揭秘传输层如何从不可靠的网络中构建绝对可靠的通信信道
java·linux·开发语言·数据结构·c++·python·算法
重生之后端学习5 小时前
78. 子集
java·数据结构·算法·职场和发展·深度优先
Jasmine_llq5 小时前
<P5464 缩小社交圈>
排序算法·预处理·前缀和与差分·动态规划(区间 dp)·快速读入·模运算处理·区间查询与更新
kronos.荒5 小时前
滑动窗口+哈希表:最小覆盖子串
数据结构·python·散列表
wostcdk5 小时前
筛质数汇总
数据结构·算法
qq_454245036 小时前
BuildTemplateGraph 函数深度解析:动态节点图构建的架构设计与核心价值
数据结构·c#
qq_454245037 小时前
SkeletonFlow:基于组合子逻辑与范畴论的数据流处理框架
数据结构·c#
逆境不可逃8 小时前
【春节篇】LeetCode 热题 100 之 238.除了自身以外数组的乘积
数据结构·算法·leetcode
散峰而望8 小时前
【算法竞赛】堆和 priority_queue
开发语言·数据结构·c++·算法·贪心算法·动态规划·推荐算法
重生之后端学习8 小时前
46. 全排列
数据结构·算法·职场和发展·深度优先·图论