导读:第一章数据结构与算法主要学习算法、数据结构的基本概念、线性表及其顺序存储结构、栈和队列、线性链表、树与二叉树、查找技术、排序技术等知识要点。

第一章 数据结构与算法

  1.1 算法

  算法:是指解题方案的准确而完整的描述。

  算法不等于程序,也不等计算机方法,程序的编制不可能优于算法的设计。

  算法的基本特征:是一组严谨地定义运算顺序的规则,每一个规则都是有效的,是明确的,此顺序将在有限的次数下终止。特征包括:

  (1)可行性;

  (2)确定性,算法中每一步骤都必须有明确定义,不充许有模棱两可的解释,不允许有多义性;

  (3)有穷性,算法必须能在有限的时间内做完,即能在执行有限个步骤后终止,包括合理的执行时间的含义;

  (4)拥有足够的情报。

  算法的基本要素:一是对数据对象的运算和操作;二是算法的控制结构。

  指令系统:一个计算机系统能执行的所有指令的集合。

  基本运算包括:算术运算、逻辑运算、关系运算、数据传输。

  算法的控制结构:顺序结构、选择结构、循环结构。

  算法基本设计方法:列举法、归纳法、递推、递归、减斗递推技术、回溯法。

  算法复杂度:算法时间复杂度和算法空间复杂度。

  算法时间复杂度是指执行算法所需要的计算工作量。

  算法空间复杂度是指执行这个算法所需要的内存空间。

  1.2 数据结构的基本概念

  数据结构研究的三个方面:

  (1)数据集合中各数据元素之间所固有的逻辑关系,即数据的逻辑结构;

  (2)在对数据进行处理时,各数据元素在计算机中的存储关系,即数据的存储结构;

  (3)对各种数据结构进行的运算。

  数据结构是指相互有关联的数据元素的集合。

  数据的逻辑结构包含:

  (1)表示数据元素的信息;

  (2)表示各数据元素之间的前后件关系。

  数据的存储结构有顺序、链接、索引等。

  线性结构条件:

  (1)有且只有一个根结点;

  (2)每一个结点最多有一个前件,也最多有一个后件。

  非线性结构:不满足线性结构条件的数据结构。

  1.3 线性表及其顺序存储结构

  线性表是由一组数据元素构成,数据元素的位置只取决于自己的序号,元素之间的相对位置是线性的。

  在复杂线性表中,由若干项数据元素组成的数据元素称为记录,而由多个记录构成的线性表又称为文件。

  非空线性表的结构特征:

  (1)且只有一个根结点a1,它无前件;

  (2)有且只有一个终端结点an,它无后件;

  (3)除根结点与终端结点外,其他所有结点有且只有一个前件,也有且只有一个后件。结点个数n称为线性表的长度,当n=0时,称为空表。

  线性表的顺序存储结构具有以下两个基本特点:

  (1)线性表中所有元素的所占的存储空间是连续的;

  (2)线性表中各数据元素在存储空间中是按逻辑顺序依次存放的。

  ai的存储地址为:ADR(ai)=ADR(a1)+(i-1)k,,ADR(a1)为第一个元素的地址,k代表每个元素占的字节数。

  顺序表的运算:插入、删除。(详见14--16页)

 1.4 栈和队列

  栈是限定在一端进行插入与删除的线性表,允许插入与删除的一端称为栈顶,不允许插入与删除的另一端称为栈底。

  栈按照“先进后出”(FILO)或“后进先出”(LIFO)组织数据,栈具有记忆作用。用top表示栈顶位置,用bottom表示栈底。

  栈的基本运算:(1)插入元素称为入栈运算;(2)删除元素称为退栈运算;(3)读栈顶元素是将栈顶元素赋给一个指定的变量,此时指针无变化。

  队列是指允许在一端(队尾)进入插入,而在另一端(队头)进行删除的线性表。Rear指针指向队尾,front指针指向队头。

  队列是“先进行出”(FIFO)或“后进后出”(LILO)的线性表。

  队列运算包括(1)入队运算:从队尾插入一个元素;(2)退队运算:从队头删除一个元素。

  循环队列:s=0表示队列空,s=1且front=rear表示队列满

  1.5 线性链表

  数据结构中的每一个结点对应于一个存储单元,这种存储单元称为存储结点,简称结点。

  结点由两部分组成:(1)用于存储数据元素值,称为数据域;(2)用于存放指针,称为指针域,用于指向前一个或后一个结点。

  在链式存储结构中,存储数据结构的存储空间可以不连续,各数据结点的存储顺序与数据元素之间的逻辑关系可以不一致,而数据元素之间的逻辑关系是由指针域来确定的。

  链式存储方式即可用于表示线性结构,也可用于表示非线性结构。

  线性链表,HEAD称为头指针,HEAD=NULL(或0)称为空表,如果是两指针:左指针(Llink)指向前件结点,右指针(Rlink)指向后件结点。

  线性链表的基本运算:查找、插入、删除。

  1.6 树与二叉树

  树是一种简单的非线性结构,所有元素之间具有明显的层次特性。

  在树结构中,每一个结点只有一个前件,称为父结点,没有前件的结点只有一个,称为树的根结点,简称树的根。每一个结点可以有多个后件,称为该结点的子结点。没有后件的结点称为叶子结点。

  在树结构中,一个结点所拥有的后件的个数称为该结点的度,所有结点中最大的度称为树的度。树的最大层次称为树的深度。

  二叉树的特点:(1)非空二叉树只有一个根结点;(2)每一个结点最多有两棵子树,且分别称为该结点的左子树与右子树。

  二叉树的基本性质:

  (1)在二叉树的第k层上,最多有2k-1(k≥1)个结点;

  (2)深度为m的二叉树最多有2m-1个结点;

  (3)度为0的结点(即叶子结点)总是比度为2的结点多一个;

  (4)具有n个结点的二叉树,其深度至少为[log2n]+1,其中[log2n]表示取log2n的整数部分;

  (5)具有n个结点的完全二叉树的深度为[log2n]+1;

  (6)设完全二叉树共有n个结点。如果从根结点开始,按层序(每一层从左到右)用自然数1,2,….n给结点进行编号(k=1,2….n),有以下结论:

  ①若k=1,则该结点为根结点,它没有父结点;若k>1,则该结点的父结点编号为INT(k/2);

  ②若2k≤n,则编号为k的结点的左子结点编号为2k;否则该结点无左子结点(也无右子结点);

  ③若2k+1≤n,则编号为k的结点的右子结点编号为2k+1;否则该结点无右子结点。

  满二叉树是指除最后一层外,每一层上的所有结点有两个子结点,则k层上有2k-1个结点深度为m的满二叉树有2m-1个结点。

  完全二叉树是指除最后一层外,每一层上的结点数均达到最大值,在最后一层上只缺少右边的若干结点。

  二叉树存储结构采用链式存储结构,对于满二叉树与完全二叉树可以按层序进行顺序存储。

  二叉树的遍历:

  (1)前序遍历(DLR),首先访问根结点,然后遍历左子树,最后遍历右子树;

  (2)中序遍历(LDR),首先遍历左子树,然后访问根结点,最后遍历右子树;

  (3)后序遍历(LRD)首先遍历左子树,然后访问遍历右子树,最后访问根结点。

  1.7 查找技术

  顺序查找的使用情况:

  (1)线性表为无序表;

  (2)表采用链式存储结构。

  二分法查找只适用于顺序存储的有序表,对于长度为n的有序线性表,最坏情况只需比较log2n次。

  1.8 排序技术

  排序是指将一个无序序列整理成按值非递减顺序排列的有序序列。

  交换类排序法:(1)冒泡排序法,需要比较的次数为n(n-1)/2;(2)快速排序法。

  插入类排序法:(1)简单插入排序法,最坏情况需要n(n-1)/2次比较;(2)希尔排序法,最坏情况需要O(n1.5)次比较。

  选择类排序法:(1)简单选择排序法, 最坏情况需要n(n-1)/2次比较;(2)堆排序法,最坏情况需要O(nlog2n)次比较。

转载于:https://www.cnblogs.com/baidongtan/archive/2012/08/30/2663729.html

二级公共基础之——数据结构与算法相关推荐

  1. 【NCRE学习笔记002】二级公共基础知识----数据结构与算法

    目录 1.算法复杂度 2.数据结构 3.逻辑结构和存储结构 4.线性结构和非线性结构 5.栈 6.队列 7.链表 8.二叉树 9.二叉树概念及其基本性质 10.二叉树遍历 11.查找 12.顺序查找 ...

  2. 计算机基础知识教程算法,快速掌握!计算机二级公共基础知识教程:算法

    小编所收集到的相关计算机二级公共基础知识教程:算法的资料 大家要认真阅读哦! 算法是指解题方案的准确而完整的描述.即是一组严谨地定义运算顺序的规则,并且每一个规则都是有效的,且是明确的,没有二义性,同 ...

  3. 计算机二级公共基础知识点

    计算机二级公共基础知识点 一.算法 1.1 基本概念 1.1.1 算法基本特征 1.1.2 算法基本要素 1.1.3 算法设计的基本方法 1.2 算法复杂度 1.2.1 问题的规模函数 1.2.2 算 ...

  4. python二级公共基础知识

    python二级公共基础知识 一.算法和数据结构 算法及其基本特征: 算法是对解题方法的准确而完整的描述. 算法的四个基本特征:可行性,确定性,有穷性,拥有足够的情报.  算法的复杂度: 算法的时间复 ...

  5. 计算机二级公共基础知识总结百度云,计算机二级公共基础知识总结详细版本[精]...

    计算机二级公共基础知识总结详细版本[精] (15页) 本资源提供全文预览,点击全文预览即可全文预览,如果喜欢文档就下载吧,查找使用更方便哦! 15.9 积分 全国计算机等级考试二级公共基础知识总结第一 ...

  6. 计算机二级公共基础知识证书,计算机二级公共基础知识

    计算机二级公共基础知识 下面是小编收集整理的计算机二级公共基础知识,希望对您有所帮助!如果你觉得不错的话,欢迎分享! 第一章 数据结构与算法 1.1算法 算法:是指解题方案的准x而完整的描述. 算法不 ...

  7. 全国计算机等级考试——二级公共基础知识辅导讲义 卿勇军主讲

    全国计算机等级考试--二级公共基础知识辅导讲义 卿勇军主讲 第一章数据结构与算法 1.1算法 1.算法是指解题方案的准确而完整的描述.换句话说,算法是对特定问题求解步骤的一种描述. *:算法不等于程序 ...

  8. 全国计算机二级考试vf知识点总结,VF全国计算机等级考试二级公共基础知识点总结.doc...

    VF全国计算机等级考试二级公共基础知识点总结 第一章数据结构与算法 算法的基本特征:可行性,确定性,有穷性,拥有足够的情报. 算法的三种基本控制结构:顺序,选择,循环. 算法的复杂度主要包括:时间复杂 ...

  9. 新视野教育计算机题库,校园网.新视野教育计算机等级考试《二级公共基础》课后习题答案...

    <二级公共基础>课后习题答案 第一章 第一节 1.答案:D 解析:算法的时间复杂度不仅与问题的规模有关,而且与输入数据有关,即输入数据所有的可能取值范围及输入各种数据或数据集的概率有关.所 ...

  10. 计算机二级考试基础知识总结,全国计算机等级考试二级公共基础知识总结

    全国计算机等级考试二级公共基础知识总结 第一章数据结构与算法 1.1 算法 1.算法的基本特征:可行性:确定性,有穷性:拥有足够的情报., 2.确定性:算法中每一步骤都必须有明确定义,不充许有模棱两可 ...

最新文章

  1. Leetcode | 3Sum
  2. 数字电视接口(HDMI,DVI)
  3. 蓝桥杯练习系统习题-基础训练
  4. 【考研保研直通车】C9高校考研真题
  5. 中国豪华的政府大楼VS破学校
  6. [导入]MsAjax Lib- Date.format 函数
  7. 测试人员与开发人员沟通的一些问题
  8. RDS PG如何安装DTS需要的增量迁移插件?
  9. 风控中英文术语手册(银行_消费金融信贷业务)_v4
  10. CNN——基于CNN的车牌号识别
  11. 神经网络学习小记录61——Tensorflow2 搭建常见分类网络平台(VGG16、MobileNet、ResNet50)
  12. 超详细!基于树莓派Python编程使用dht11温湿度模块
  13. FatFs 之三 FAT文件系统基础、FAT 数据格式、引导、编码
  14. [爬虫] Python监测L优惠券发放网站并通过邮件通知我
  15. 自然语言处理 情绪识别
  16. c# 如何打印条形码
  17. 图论 —— 染色法判断二分图
  18. MT7621芯片性能,MT7621路由器参数介绍
  19. html 图片重叠效果,CSS实现照片堆叠效果的实例代码
  20. 腾达n4怎么设置虚拟服务器,腾达n4路由器怎么设置

热门文章

  1. sql中exist()的用法
  2. Dictionary Union and Sort by value
  3. 标记语言——邪恶的表格?
  4. python 回溯法 子集树模板 系列 —— 4、数字组合问题
  5. 解决Mac下Parallels Desktop的Host-only网络问题
  6. java面试题整理(二)
  7. 5.编译并运行erlang程序
  8. .NET Framework第一二课(7/26、27)
  9. Flex与.NET互操作(十五):使用FluorineFx中的字节数组(ByteArray)实现图片上传
  10. 134. PHP 工具