《2022年数据结构与算法基础知识总结.docx》由会员分享,可在线阅读,更多相关《2022年数据结构与算法基础知识总结.docx(8页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、精选学习资料 - - - - - - - - - 学习必备 欢迎下载数据结构与算法基础学问总结1 算法算法:是指解题方案的精确而完整的描述;算法不等于程序,也不等运算机方法,程序的编制不行能优于算法的设计;算法的基本特点:是一组严谨地定义运算次序的规章,每一个规章都是有效的,是明确的,此次序将在有限的次数下终止;特点包括:(1)可行性;(2)确定性,算法中每一步骤都必需有明确定义,不充许有模棱两可的说明,不答应有多 义性;(3)有穷性,算法必需能在有限的时间内做完,即能在执行有限个步骤后终止,包括合理 的执行时间的含义;(4)拥有足够的情报;算法的基本要素:一是对数据对象的运算和操作;二是算法
2、的掌握结构;指令系统:一个运算机系统能执行的全部指令的集合;基本运算和操作包括:算术运算、规律运算、关系运算、数据传输;算法的掌握结构:次序结构、挑选结构、循环结构;算法基本设计方法:列举法、归纳法、递推、递归、减斗递推技术、回溯法;算法复杂度:算法时间复杂度和算法空间复杂度;算法时间复杂度是指执行算法所需要的运算工作量;算法空间复杂度是指执行这个算法所需要的内存空间;2 数据结构的基本基本概念数据结构讨论的三个方面:(1)数据集合中各数据元素之间所固有的规律关系,即数据的规律结构;(2)在对数据进行处理时,各数据元素在运算机中的储备关系,即数据的储备结构;(3)对各种数据结构进行的运算;数据
3、结构是指相互有关联的数据元素的集合;数据的规律结构包含:(1)表示数据元素的信息;(2)表示各数据元素之间的前后件关系;数据的储备结构有次序、链接、索引等;线性结构条件:名师归纳总结 - - - - - - -第 1 页,共 4 页精选学习资料 - - - - - - - - - 学习必备 欢迎下载(1)有且只有一个根结点;(2)每一个结点最多有一个前件,也最多有一个后件;非线性结构:不满意线性结构条件的数据结构;3 线性表及其次序储备结构线性表由一组数据元素构成,数据元素的位置只取决于自己的序号,元素之间的相对位置是线性的;在复杂线性表中, 由如干项数据元素组成的数据元素称为记录,又称为文件
4、;非空线性表的结构特点:(1)且只有一个根结点 a1,它无前件;(2)有且只有一个终端结点 an,它无后件;而由多个记录构成的线性表(3)除根结点与终端结点外,其他全部结点有且只有一个前件,也有且只有一个后件;结 点个数 n 称为线性表的长度,当 n=0 时,称为空表;线性表的次序储备结构具有以下两个基本特点:(1)线性表中全部元素的所占的储备空间是连续的;(2)线性表中各数据元素在储备空间中是按规律次序依次存放的;ai 的储备地址为: adrai=adra1+i-1k, ,adra1为第一个元素的地址,k 代表每个元素占的 字节数;次序表的运算:插入、删除;(详见 14-16 页)4 栈和队
5、列栈是限定在一端进行插入与删除的线性表,答应插入与删除的一端称为栈顶,不答应插入与删除的另一端称为栈底;栈根据 “先进后出 ”( filo )或 “ 后进先出 ” (lifo )组织数据,栈具有记忆作用;用 top 表示栈 顶位置,用 bottom 表示栈底;栈的基本运算: (1)插入元素称为入栈运算; ( 2)删除元素称为退栈运算; (3)读栈顶元素 是将栈顶元素赋给一个指定的变量,此时指针无变化;rear 指针 队列是指答应在一端(队尾)进入插入,而在另一端(队头)进行删除的线性表;指向队尾, front 指针指向队头;队列是 “先进行出 ”( fifo )或 “ 后进后出 ”(lilo
6、)的线性表;队列运算包括( 1)入队运算:从队尾插入一个元素;(2)退队运算:从队头删除一个元素;循环队列: s=0 表示队列空, s=1 且 front=rear 表示队列满名师归纳总结 - - - - - - -第 2 页,共 4 页精选学习资料 - - - - - - - - - 学习必备 欢迎下载5 线性链表数据结构中的每一个结点对应于一个储备单元,这种储备单元称为储备结点,简称结点;结点由两部分组成: (1)用于储备数据元素值,称为数据域;域,用于指向前一个或后一个结点;(2)用于存放指针,称为指针在链式储备结构中,储备数据结构的储备空间可以不连续,各数据结点的储备次序与数据元素之间
7、的规律关系可以不一样,而数据元素之间的规律关系是由指针域来确定的;链式储备方式即可用于表示线性结构,也可用于表示非线性结构;线性链表, head 称为头指针, head=null (或 0)称为空表,假如是两指针:左指针(llink )指向前件结点,右指针(rlink )指向后件结点;线性链表的基本运算:查找、插入、删除;6 树与二叉树树是一种简洁的非线性结构,全部元素之间具有明显的层次特性;在树结构中,每一个结点只有一个前件,称为父结点,没有前件的结点只有一个,称为树的 根结点,简称树的根;每一个结点可以有多个后件,称为该结点的子结点;没有后件的结点 称为叶子结点;在树结构中, 一个结点所拥
8、有的后件的个数称为该结点的度,度;树的最大层次称为树的深度;全部结点中最大的度称为树的二叉树的特点: (1)非空二叉树只有一个根结点;(2)每一个结点最多有两棵子树,且分别称为该结点的左子树与右子树;二叉树的基本性质:(1)在二叉树的第 k 层上,最多有 2k-1k 1个结点;(2)深度为 m 的二叉树最多有 2m-1 个结点;(3)度为 0 的结点(即叶子结点)总是比度为 2 的结点多一个;(4)具有 n 个结点的二叉树, 其深度至少为 log2n+1, 其中 log2n 表示取 log2n 的整数部分;(5)具有 n 个结点的完全二叉树的深度为 log2n+1 ;(6)设完全二叉树共有 n
9、 个结点;假如从根结点开头,按层序(每一层从左到右)用自然数 1,2, .n 给结点进行编号(k=1,2 .n),有以下结论:如 k=1 ,就该结点为根结点,它没有父结点;如 k1,就该结点的父结点编号为 intk/2 ;如 2kn,就编号为 k 的结点的左子结点编号为 2k;否就该结点无左子结点(也无右子结点);如 2k+1n,就编号为k 的结点的右子结点编号为2k+1;否就该结点无右子结点;满二叉树是指除最终一层外,每一层上的全部结点有两个子结点,就 深度为 m 的满二叉树有 2m-1 个结点;k 层上有 2k-1 个结点名师归纳总结 - - - - - - -第 3 页,共 4 页精选学
10、习资料 - - - - - - - - - 完全二叉树是指除最终一层外,学习必备欢迎下载在最终一层上只缺少右边每一层上的结点数均达到最大值,的如干结点;二叉树储备结构采纳链式储备结构,对于满二叉树与完全二叉树可以按层序进行次序储备;二叉树的遍历:(1)前序遍历( dlr),第一拜访根结点,然后遍历左子树,最终遍历右子树;(2)中序遍历( ldr),第一遍历左子树,然后拜访根结点,最终遍历右子树;(3)后序遍历( lrd)第一遍历左子树,然后拜访遍历右子树,最终拜访根结点;7 查找技术次序查找的使用情形:(1)线性表为无序表;(2)表采纳链式储备结构;二分法查找只适用于次序储备的有序表,对于长度为 log2n 次;8 排序技术n 的有序线性表,最坏情形只需比较排序是指将一个无序序列整理成按值非递减次序排列的有序序列;交换类排序法: (1)冒泡排序法,需要比较的次数为 插入类排序法: (1)简洁插入排序法,最坏情形需要 坏情形需要 on1.5 次比较;挑选类排序法: (1)简洁挑选排序法 , nn-1/2 ; ( 2)快速排序法;nn-1/2 次比较;(2)希尔排序法,最名师归纳总结 最坏情形需要nn-1/2 次比较;(2)堆排序法,最坏情形需要onlog2n 次比较;第 4 页,共 4 页- - - - - - -