计算机二级数据结构与算法

整理文档很辛苦,赏杯茶钱您下走!

免费阅读已结束,点击下载阅读编辑剩下 ...

阅读已结束,您可以下载文档离线阅读编辑

资源描述

计算机教研室全国计算机等级考试二级公共基础知识21.基本数据结构与算法31.1算法1.1.1算法(algorithm)基本概念对特定问题求解步骤的一种描述,它是指令的有限序列,其中每一条指令表示一个或多个操作。它是一组严谨地定义运算顺序的规则,并且每一个规则都是有效的,且是明确的,此顺序将在有限的次数下终止。4算法的基本特征可行性确定性有穷性拥有足够的情报–输入和输出5算法的基本要素1、对数据对象的运算和操作算术运算:加、减、乘、除等运算逻辑运算:“与”、“或”、“非”等运算关系运算:“大于”、“等于”等运算数据传输:赋值、输入、输出等运算6算法的基本要素2、算法的控制结构算法中各操作之间的执行顺序描述算法的工具通常有传统流程图、N-S结构化流程图、算法描述语言等一个算法一般可以用顺序、选择、循环三种基本机构组合而成。7算法设计基本方法–列举法–归纳法–递推–递归(以简洁的形式设计和描述算法)–减半递推技术–回溯法81.1.2算法复杂度时间复杂度–是指执行算法所需要的计算工作量。–一般用算法在执行过程中所需要的基本运算的执行次数来度量算法的工作量。–算法中基本运算执行次数和问题的规模有关。算法的工作量=f(n)–有时在固定规模下,基本运算执行次数还和具体输入有关。9平均性态最坏情况复杂性nDxxtxpnA)()()()}({max)(xtnWnDxX出现的概率算法在输入x时所执行的基本运算次数规模为n时,算法执行时所有可输入的集合10算法的空间复杂度–一般是指执行这个算法所需要的内存空间–一个算法所占用的存储空间包括算法程序所占的空间、输入的初始数据所占的存储空间以及某种数据结构所需要的附加存储空间–一个上机执行的程序除了需要存储空间来寄存本身所用指令、常数、变量和输入数据外,也需要一些对数据进行操作的工作单元和存储一些为实现计算所需信息的辅助空间。111.2数据结构数据结构的定义数据的逻辑结构和存储结构数据结构的图形表示线性结构与非线性结构121.2.1数据结构研究的主要内容当今计算机应用的特点:所处理的数据量大且具有一定的关系;对其操作不再是单纯的数值计算,而更多地是需要对其进行组织、管理和检索。13应用举例——学籍档案管理假设用计算机管理学生档案,研究对象为:学生,常用操作查找、删除、修改、插入等一个学籍档案管理系统应包含如下表1-1所示的学生信息。14学生基本情况学号姓名性别出生年月......99070101李军男80.12......99070102王颜霞女81.2.......99070103孙涛男80.9......99070104单晓宏男81.3....................................15特点:每个学生的信息占据一行,所有学生的信息按学号顺序依次排列构成一张表格。表中每个学生的信息依据学号的顺序存在着一种前后关系,这就是我们所说的线性结构。对它的操作通常是插入某个学生的信息,删除某个学生的信息,更新某个学生的信息,按条件检索某个学生的信息等等。16数据结构是一门研究数据组织、存储和运算的一般方法的学科。1.2.2基本概念和术语数据结构主要研究和讨论以下三个方面的问题:1.数据集合中各数据元素之间所固有的逻辑关系,即数据的逻辑结构。2.在对数据进行处理时,各数据元素在计算机中的存储关系,即数据的存储结构。3.对各种数据结构进行的运算。位置:P6,重要。17能输入到计算机中并能被计算机程序处理的符号的集合。整数(1,2)、实数(1.1,1.2)字符串(Beijing)、图形、声音。1.2.2基本概念和术语数据结构是一门研究数据组织、存储和运算的一般方法的学科。181.2.2基本概念和术语计算机管理图书问题在图书馆里有各种卡片:有按书名编排的、有按作者编排的、有按分类编排如何将查询图书的这些信息存入计算机中既要考虑查询时间短,又要考虑节省空间数据结构是一门研究数据组织、存储和运算的一般方法的学科。19最简单的办法之一是建立一张表,每一本书的信息在表中占一行,如1.2.2基本概念和术语数据结构是一门研究数据组织、存储和运算的一般方法的学科。20将各种逻辑结构的数据存放在计算机存储空间中。目的不同,最佳的存储方方法就不同。数据元素在计算机中的表示数据结构是一门研究数据组织、存储和运算的一般方法的学科。1.2.2基本概念和术语21对数据结构中的节点进行操作处理(插入、删除、修改、查找、排序)1.2.2基本概念和术语数据结构是一门研究数据组织、存储和运算的一般方法的学科。22数据元素(DataElement)现实世界中客观存在得一切个体或个体相关的操作都可以抽象为数据元素。如:四季的名称:春、夏、秋、冬由季节抽象而来,可以作为季节的数据元素。同理,父亲、儿子、女儿可以作为家庭成员的数据元素。简单的说,数据结构是指相互有关联的数据元素的集合。23数据元素(DataElement)甚至客观存在的事件,如演出、借书、比赛等也可以抽象为数据元素。在具有相同特征的数据元素集合中,各个数据元素之间存在某种关系,这种关系反映了该集合中的数据元素所固有的一种结构。在数据处理领域中,通常把数据元素之间的这种固有的关系简单地用前后件关系来描述。24数据的逻辑结构表示数据元素的信息表示数据元素之间的前后件关系。数据逻辑结构通常用二元组表示数据逻辑结构也可用图形表示25数据逻辑结构可表示为:B=(D,R)B表示数据结构D表示数据元素的集合R表示数据元素间前后件关系为反映前后件关系,通常用二元组(a,b)来表示,它表示a是b的前件。26B=(D,R)D={父亲,儿子,女儿}R={(父亲,儿子),(父亲,女儿)}B=(D,R)D={春,夏,秋,冬}R={(春,夏),(夏,秋),(秋,冬)}27数据结构的图形表示春夏秋冬一年四季数据结构的图形表示ABCD28数据的存储结构数据的逻辑结构在计算机存储空间的表示。各数据元素在计算机存储空间中的位置与逻辑关系不一定相同。常用的存储结构有:顺序、链接、索引等。29数据的存储结构....6427531....字节....6427531....冬夏秋春....6427531....儿子女儿4006父亲30二级公共基础05年4月试题(1)数据的存储结构是指A)存储在外存中的数据B)数据所占的存储空间量C)数据在计算机中的顺序存储方式D)数据的逻辑结构在计算机中的表示31线性结构与非线性结构有且只有一个根结点(没有前件的结点)。每一个结点最多只有一个前件,也最多只有一个后件。32线性结构A,B,C,·······,X,Y,Z学生成绩表86胡孝臣986110395刘忠赏9861107100张卓9861109成绩姓名学号线性表——结点间是以线性关系联结ABC33非线性结构如果数据结构不满足线性结构的条件,则称之为非线性结构。此外,在线线结构中插入或删除一个结点,还应是线线结构,否则此结构非线线ABCD34树形结构全校学生档案管理的组织方式计算机程序管理系统也是典型的树形结构35ABCDEFGH树形结构——结点间具有分层次的连接关系HBCDEFGA361.3线性表1.3.1线性表的定义线性表是n个元素的有限序列,它们之间的关系可以排成一个线性序列:a1,a2,……,ai,……,an其中n称作表的长度,当n=0时,称作空表。37线性表的特点:1.线性表中所有元素的性质相同。2.除第一个和最后一个数据元素之外,其它数据元素有且仅有一个前件和一个后件。第一个数据元素无前件,最后一个数据元素无后件。3.数据元素在表中的位置只取决于它自身的序号。在线性表上常用的运算有:初始化、求长度、取元素、修改、前插、删除、检索、排序。381.3.2线性表的顺序存储结构线性表顺序存储结构的特点:1、线性表所有元素所占的存储空间是连续的。2、线性表各数据元素在存储空间中是按逻辑顺序依次存放的。在计算机中存放线性表,采用顺序存储是一种简单方便的方法。39元素an……..元素ai……..元素a2元素a1bADR(a1)+k存储地址内存状态顺序存储结构示意图(顺序表):首地址ADR(a1)每个元素所占用的存储单元个数ADR(a1)+(i-1)*kADR(a1)+(n-1)*kADR(ai)=ADR(a1)+(i-1)*k40n-1线性表的插入和删除运算示意图ai-1…..a2a1an…ai+1aixai-1…..a2a1aiai+1…alengthan……ai+1aix删除运算插入运算41若长度为n的线性表表示为:(a1,a2,…,ai,…an)运算后表示为:(a’1,a’2,…,a’i,…a’n),则满足以下关系:插入新元素b后a’jaj1=j=i-1bj=iaj-1i+1=j=n+1长度增加为:n+1删除第i个元素后a’jaj1=j=i-1aj+1i=j=n-1长度减少为:n-1421.4栈和队列1.4.1栈和队列的定义栈和队列是两种特殊的线性表,它们是运算时要受到某些限制的线性表,故也称为限定性的数据结构。431.4.1.1栈的定义栈:限定只能在表的一端进行插入和删除的特殊的线性表,此种结构称为先进后出(FILO)或后进先出(LIFO)设栈s=(a1,a2,...,ai,...,an),其中a1是栈底元素,an是栈顶元素。栈顶(top):允许插入和删除的一端;栈底(bottom):不允许插入和删除的一端。约定用指针top始终指向栈顶的位置,用指针bottom指向栈底。a1a2….ai进栈出栈topbottomn1441.4.2栈的顺序存储结构及其基本运算a2a1a1a2top用顺序存储结构表示的栈。顺序栈用一组连续的存储单元存放自栈底到栈顶的数据元素,一般用一维数组表示,设置一个简单变量top指示栈顶位置,称为栈顶指针,它始终指向待插入元素的位置。基本运算:压(进)栈:PUSH出栈:POP读栈顶元素45进栈示例栈满:栈顶指针指向存储空间的最后一个位置46退栈示例471.4.1.2队列(Queue)的定义定义:一种特殊的线性结构,限定只能在表的一端进行插入,在表的另一端进行删除的线性表。a1,a2,a3,a4,…………an-1,an队列示意图队头队尾队列只允许在队尾插入,在对头删除。队头指针:front:指向排头元素的前一个位置队尾指针:rear:指向队尾元素此种结构称为先进先出(FIFO)或后进后出(LILO)。48队列的主要运算(1)插入一个新的队尾元素,称为进队;(2)删除队头元素,称为出队;(3)读取队头元素;当有新元素入队时,尾指针加1,当有元素出队时,头指针加1。故在非空队列中,头指针始终指向队头元素前一个位置,而尾指针始终指向队尾元素的位置49队列的进队和出队进队时队尾指针先进一rear=rear+1,再将新元素按rear指示位置加入。出队时队头指针先进一front=front+1,再将下标为front的元素取出。队满时再进队将溢出出错;队空时再出队将队空处理。队满:队尾指针指向存储空间的最后一个位置50定义:存储队列的线型空间被模拟为首尾相接的环形空间处理。循环队列(长度为m)的的性质:循环队列的初始状态:front=rear=m队头、队尾指针加1时若结果等于m+1置为1。循环队列(CircularQueue)51Q(1:m)…21mrearfront52Q(1:6)rearfrontAECDBF53队空时:front==rear;队满时:front==rear由于队满和对空的条件一样,无法判断循环队列的状态,所以增加了一个标志s,s的定义如下:s1表示队列非空0表示队列空P19-20详细说明541.5链表线性链表指针数据线性链表节点指针数据指针数据551.5.1线性表的链式存储结构将线性表的元素放到一个具有头指针的链表中,链表中每个结点包含数据域和指针域。数据域存放数据,指针域存放后继结点的地址,最后一个结点的指针域为空。逻辑上相邻的数据元素在内存中的物理存储空间不一定相

1 / 67
下载文档,编辑使用

©2015-2020 m.777doc.com 三七文档.

备案号:鲁ICP备2024069028号-1 客服联系 QQ:2149211541

×
保存成功