【数据结构】填空集

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

相关推荐
田梓燊4 小时前
力扣:23.合并 K 个升序链表
算法·leetcode·链表
AI人工智能+电脑小能手5 小时前
【大白话说Java面试题】【Java基础篇】第15题:JDK1.7中HashMap扩容为什么会发生死循环?如何解决
java·开发语言·数据结构·后端·面试·哈希算法
Mrlxl.cn8 小时前
计算机网络——网络层
c语言·数据结构·计算机网络·考研
寒秋花开曾相惜9 小时前
(学习笔记)4.2 逻辑设计和硬件控制语言HCL(4.2.1 逻辑门&4.2.2 组合电路和HCL布尔表达式)
linux·网络·数据结构·笔记·学习·fpga开发
Mrlxl.cn11 小时前
计算机网络——传输层
c语言·计算机网络·考研·排序算法
6Hzlia11 小时前
【Hot 100 刷题计划】 LeetCode 141. 环形链表 | C++ 哈希表直觉解法
c++·leetcode·链表
码完就睡12 小时前
数据结构——哈希表原理与C语言实现总结
数据结构·散列表
山甫aa13 小时前
二叉树遍历----从零开始的数据结构
数据结构·c++·二叉树
北顾笙98014 小时前
day35-数据结构力扣
数据结构·算法·leetcode
cpp_250114 小时前
P2249 【深基13.例1】查找
数据结构·c++·算法·题解·二分·洛谷