【数据结构】填空集

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

相关推荐
bbq粉刷匠10 小时前
Java-排序2
java·数据结构·排序算法
TracyCoder12310 小时前
Redis 进阶之路:探秘事务、Lua 与特殊数据结构
数据结构·redis·lua
睡一觉就好了。11 小时前
归并排序——递归与非递归的双重实现
数据结构·算法·排序算法
懈尘11 小时前
深入理解Java的HashMap扩容机制
java·开发语言·数据结构
ValhallaCoder11 小时前
hot100-矩阵
数据结构·python·算法·矩阵
散峰而望11 小时前
【基础算法】穷举的艺术:在可能性森林中寻找答案
开发语言·数据结构·c++·算法·随机森林·github·动态规划
散峰而望12 小时前
【基础算法】算法的“预谋”:前缀和如何改变游戏规则
开发语言·数据结构·c++·算法·github·动态规划·推荐算法
仰泳的熊猫12 小时前
题目1432:蓝桥杯2013年第四届真题-剪格子
数据结构·c++·算法·蓝桥杯·深度优先·图论
sin_hielo12 小时前
leetcode 3010
数据结构·算法·leetcode
仙俊红14 小时前
LeetCode487周赛T2,删除子数组后的最终元素
数据结构·算法