【技术点】嵌入式技术考点三:数据结构

文章目录

1.什么叫做链表,链表的操作有哪些?

  链表:是一种常见的数据结构,它由一系列节点组成,每个节点包含一个数据元素和一个指向下一个节点的指针。

  链表的操作包括以下几种:

   (1)插入操作 :在链表中插入一个新节点,可以在链表的头部、尾部或者中间插入。

   (2)删除操作 :从链表中删除一个节点,可以删除链表的头部、尾部或者中间的节点。

   (3)查找操作 :在链表中查找一个节点,可以根据节点的值或者位置进行查找。

   (4)修改操作 :在链表中查找一个节点,并修改查找到的值。

   (5)排序操作:对链表中的节点进行排序,可以按照节点的值或者位置进行排序。

2.排序算法有哪些?时间复杂度如何?如何实现的?

  1. 冒泡排序(Bubble Sort):时间复杂度为O(n^2)。相邻的两个数进行比较,较大的则进行交换,依次往右进行比较,直到将最大的数值排到最右边,再按照上述顺序完成全部数据的排序。
  2. 选择排序(Selection Sort):时间复杂度为O(n^2)。首先在未排序序列中找到最小(大)元素,存放到排序序列的起始位置,再从剩余未排序元素中继续寻找最小(大)元素,然后放到已排序序列的末尾,重复操作。
  3. 插入排序(Insertion Sort):时间复杂度为O(n^2)。将未排序的数字插入到已排序的数列中。
  4. 希尔排序(Shell Sort):时间复杂度为O(nlogn)。
  5. 归并排序(Merge Sort):时间复杂度为O(nlogn)。
  6. 快速排序(Quick Sort):时间复杂度为O(nlogn)。

  选择一个基准元素(通常为待排序数组的第一个或最后一个元素)。将待排序数组划分为两个子数组,使得左侧的子数组元素均小于等于基准元素,右侧的子数组元素均大于基准元素。

  对左右子数组递归地执行步骤1和步骤2,直到子数组长度为1或0,递归终止。

  合并所有子数组,即得到排序后的数组。

3.衡量算法的性能是什么?

衡量算法性能的主要指标有以下几个:

  (1)时间复杂度:算法执行所需的时间,通常用大O符号表示。时间复杂度越小,算法执行速度越快。

  (2)空间复杂度:算法执行所需的内存空间,通常用大O符号表示。空间复杂度越小,算法所需的内存空间越少。

  (3)精确度:算法的输出结果与实际结果的误差大小。精确度越高,算法的输出结果越接近实际结果。

4.栈和队列的区别是什么?那个速率更快?

栈:一种先进后出(Last In First Out,LIFO)的数据结构。

队列:一种先进先出(First In First Out,FIFO)的数据结构。

区别:

 (1)存储方式:栈是一种后进先出(Last-In-First-Out,LIFO)的数据结构,元素按照插入的顺序存储,最后插入的元素被称为栈顶,第一个插入的元素被称为栈底。

  队列是一种先进先出(First-In-First-Out,FIFO)的数据结构,元素按照插入的顺序存储,第一个插入的元素被称为队头,最后插入的元素被称为队尾。

 (2)操作方式:栈主要支持两种基本操作,入栈(Push)和出栈(Pop)。入栈操作将元素压入栈顶,出栈操作将栈顶元素弹出。

  队列主要支持两种基本操作,即入队(Enqueue)和出队(Dequeue)。入队操作将元素插入到队尾,出队操作将队头元素移除。

 (3)应用场景:栈常用于需要后进先出操作的场景。队列常用于需要先进先出操作的场景。

速率:用于反复进行插入和删除操作的场景中,栈可能更为高效。用于需要先进先出操作的场景,队列可能更为高效。

5.什么是双向循环链表,谈谈你的理解?

  双向循环链表:是一种链表数据结构,每个节点除了存储数据以外,还包含两个指针:一个指向前一个节点的指针(前驱指针或prev指针),一个指向后一个节点的指针(后继指针或next指针)。

  它与单向链表不同之处在于,双向循环链表的最后一个节点的后继指针指向第一个节点,而第一个节点的前驱指针指向最后一个节点,形成一个循环的闭合结构。

6.什么是平衡二叉树?

平衡二叉树:左右子树都是平衡二叉树 且左右子树的深度差值的绝对值不大于1

7. 时间复杂度 / 空间复杂度是什么?

  • 时间:执行次数随数据规模增长趋势
  • 空间:额外占用内存
  • 常见复杂度(从快到慢):O(1) < O(log n) < O(n) < O(n log n) < O(n²) < O(2ⁿ)
相关推荐
刀法如飞7 小时前
AI时代:DDD领域驱动建模与Ontology语义建模的区别
java·设计模式·架构
jeffer_liu7 小时前
Spring AI 生产级实战:工具调用
java·人工智能·后端·spring·ai编程
比昨天多敲两行7 小时前
linux 线程概念与控制
java·开发语言·jvm
8Qi87 小时前
LeetCode 75:颜色分类(荷兰国旗问题)—— Java 题解 ✅
java·算法·leetcode·指针·排序
zzhongcy7 小时前
@Transactional 同类内部调用失效 + 两种自代理解决方案
java
AutumnWind04208 小时前
【Intelij IDEA使用手册】
java·ide·intellij-idea
888CC++9 小时前
如何在 C 语言中进行程序调试?
前端·javascript·算法
就叫_这个吧9 小时前
Java注解、元注解、自定义注解定义及应用
java·开发语言·注解
Sam_Deep_Thinking9 小时前
聊聊Java中的of
java·开发语言·架构