【数据结构】填空集

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

相关推荐
2401_8920709819 分钟前
顺序栈(动态数组实现) 超详细解析(C++ 语言 + 可直接运行)
数据结构·c++·顺序栈
漫霂33 分钟前
二叉树的翻转
java·数据结构·算法
3秒一个大44 分钟前
深入理解 JS 中的栈与堆:从内存模型到数据结构,再谈内存泄漏
前端·javascript·数据结构
旖-旎1 小时前
哈希表(存在重复元素)(3)
数据结构·c++·学习·算法·leetcode·散列表
计算机安禾1 小时前
【数据结构与算法】第39篇:图论(三):最小生成树——Prim算法与Kruskal算法
开发语言·数据结构·c++·算法·排序算法·图论·visual studio code
汀、人工智能2 小时前
[特殊字符] 第77课:最长递增子序列
数据结构·算法·数据库架构·图论·bfs·最长递增子序列
澈2072 小时前
堆排序:高效构建大顶堆实战
数据结构·算法·排序算法
我真不是小鱼2 小时前
cpp刷题打卡记录27——无重复字符的最长子串 & 找到字符串中所有字母的异位词
数据结构·c++·算法·leetcode
qq. 28040339843 小时前
数据结构引论
前端·数据结构
历程里程碑3 小时前
1 . Git本地操作:版本控制 跨平台协作 仓库核心
java·开发语言·数据结构·c++·git·gitee·github