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