计算机二级公共基础知识全Word下载.docx
- 文档编号:20459259
- 上传时间:2023-01-23
- 格式:DOCX
- 页数:43
- 大小:63.64KB
计算机二级公共基础知识全Word下载.docx
《计算机二级公共基础知识全Word下载.docx》由会员分享,可在线阅读,更多相关《计算机二级公共基础知识全Word下载.docx(43页珍藏版)》请在冰豆网上搜索。
(2)算法的控制结构:
一个算法的功能不仅仅取决于所选用的操作,而且还与各操作之间的执行顺序有关。
算法中各操作之间的执行顺序称为算法的控制结构。
算法的控制结构给出了算法的基本框架,它不仅决定了算法中各操作的执行顺序,而且也直接反映了算法的设计是否符合结构化原则。
描述算法的工具通常有传统流程图、N-S结构化流程图、算法描述语言等。
一个算法一般都可以用顺序、选择、循环3种基本控制结构组合而成。
(3)算法设计的基本方法
计算机算法不同于人工处理的方法,下面是工程上常用的几种算法设计,在实际应用时,各种方法之间往往存在着一定的联系。
(1)列举法
列举法是计算机算法中的一个基础算法。
列举法的基本思想是,根据提出的问题,列举所有可能的情况,并用问题中给定的条件检验哪些是需要的,哪些是不需要的。
列举法的特点是算法比较简单。
但当列举的可能情况较多时,执行列举算法的工作量将会很大。
因此,在用列举法设计算法时,使方案优化,尽量减少运算工作量,是应该重点注意的。
(2)归纳法
归纳法的基本思想是,通过列举少量的特殊情况,经过分析,最后找出一般的关系。
从本质上讲,归纳就是通过观察一些简单而特殊的情况,最后总结出一般性的结论。
(3)递推
递推是指从已知的初始条件出发,逐次推出所要求的各中间结果和最后结果。
其中初始条件或是问题本身已经给定,或是通过对问题的分析与化简而确定。
递推本质上也属于归纳法,工程上许多递推关系式实际上是通过对实际问题的分析与归纳而得到的,因此,递推关系式往往是归纳的结果。
对于数值型的递推算法必须要注意数值计算的稳定性问题。
(4)递归
人们在解决一些复杂问题时,为了降低问题的复杂程度(如问题的规模等),一般总是将问题逐层分解,最后归结为一些最简单的问题。
这种将问题逐层分解的过程,实际上并没有对问题进行求解,而只是当解决了最后那些最简单的问题后,再沿着原来分解的逆过程逐步进行综合,这就是递归的基本思想。
递归分为直接递归与间接递归两种。
(5)减半递推技术
实际问题的复杂程度往往与问题的规模有着密切的联系。
因此,利用分治法解决这类实际问题是有效的。
工程上常用的分治法是减半递推技术。
所谓“减半”,是指将问题的规模减半,而问题的性质不变;
所谓“递推”,是指重复“减半”的过程。
(6)回溯法
在工程上,有些实际问题很难归纳出一组简单的递推公式或直观的求解步骤,并且也不能进行无限的列举。
对于这类问题,一种有效的方法是“试”。
通过对问题的分析,找出一个解决问题的线索,然后沿着这个线索逐步试探,若试探成功,就得到问题的解,若试探失败,就逐步回退,换别的路线再逐步试探。
4算法设计的要求
通常一个好的算法应达到如下目标:
(l)正确性(correctness)
正确性大体可以分为以下4个层次:
①程序不含语法错误;
②程序对于几组输入数据能够得出满足规格说明要求的结果;
③程序对于精心选择的典型、苛刻而带有刁难性的几组输入数据能够得出满足规格说明要求的结果;
④程序对于一切合法的输入数据都能产生满足规格说明要求的结果。
(2)可读性(readability)
算法主要是为了方便入的阅读与交流,其次才是其执行。
可读性好有助于用户对算法的理解;
晦涩难懂的程序易于隐藏较多错误,难以调试和修改。
(3)健壮性(robustness)
当输入数据非法时,算法也能适当地做出反应或进行处理,而不会产生莫名其妙的输出结果。
(4)效率与低存储量需求
效率指的是程序执行时,对于同一个问题如果有多个算法可以解决,执行时间短的算法效率高;
存储量需求指算法执行过程中所需要的最大存储空间
考点2算法的复杂度
1算法的时间复杂度
算法的时间复杂度,是指执行算法所需要的计算工作量。
同一个算法用不同的语言实现,或者用不同的编译程序进行编译,或者在不同的计算机上运行,效率均不同。
这表明使用绝对的时间单位衡量算法的效率是不合适的。
撇开这些与计算机硬件、软件有关的因素,可以认为一个特定算法“运行工作量”的大小,只依赖于问题的规模(通常用整数n表示),它是问题的规模函数。
即
算法的工作量=f(n)
例如,在N×
N矩阵相乘的算法中,整个算法的执行时间与该基本操作(乘法)重复执行的次数n3成正比,也就是时间复杂度为n3,即
f(n)=O(n3)
在有的情况下,算法中的基本操作重复执行的次数还随问题的输入数据集不同而不同。
例如在起泡排序的算法中,当要排序的数组a初始序列为自小至大有序时,基本操作的执行次数为适当初始序列为自大至小有序时,基本操作的执行次数为n(n-1)/2。
对这类算法的分析,可以采用以下两种方法来分析。
(1)平均性态(AverageBehavior)
所谓平均性态是指各种特定输入下的基本运算次数的加权平均值来度量算法的工作量。
设x是所有可能输入中的某个特定输入,p(x)是x出现的概率(即输入为x的概率),t(x)是算法在输入为x时所执行的基本运算次数,则算法的平均性态定义为
其中Dn表示当规模为n时,算法执行的所有可能输入的集合。
(2)最坏情况复杂性(Worst-caseComplexity)
所谓最坏情况分析,是指在规模为n时,算法所执行的基本运算的最大次数。
2算法的空间复杂度
算法的空间复杂度是指执行这个算法所需要的内存空间。
一个算法所占用的存储空间包括算法程序所占的空间、输入的初始数据所占的存储空间以及算法执行中所需要的额外空间。
其中额外空间包括算法程序执行过程中的工作单元以及某种数据结构所需要的附加存储空间。
如果额外空间量相对于问题规模来说是常数,则称该算法是原地(inplace)工作的。
在许多实际问题中,为了减少算法所占的存储空间,通常采用压缩存储技术,以便尽量减少不必要的额外空间。
考点3数据结构的定义
数据结构(datastructure)是指相互之间存在一种或多种特定关系的数据元素的集合,即数据的组织形式。
数据结构作为计算机的一门学科,主要研究和讨论以下三个方面:
(l)数据集合中各个数据元素之间所固有的逻辑关系,即数据的逻辑结构;
(2)在对数据元素进行处理时,各数据元素在计算机中的存储关系,即数据的存储结构;
(3)对各种数据结构进行的运算。
讨论以上问题的目的是为了提高数据处理的效率,所谓提高数据处理的效率有两个方面:
●提高数据处理的速度;
●尽量节省在数据处理过程中所占用的计算机存储空间。
数据(data):
是对客观事物的符号表示,在计算机科学中是指所有能输入到计算机中并被计算机程序处理的符号的总称。
数据元素(dataelement):
是数据的基本单位,在计算机程序中通常作为一个整体进行考虑和处理。
数据对象(dataobject):
是性质相同的数据元素的集合,是数据的一个子集。
在一般情况下,在具有相同特征的数据元素集合中,各个数据元素之间存在有某种关系(即连续),这种关系反映了该集合中的数据元素所固有的一种结构。
在数据处理领域中,通常把数据元素之间这种固有的关系简单地用前后件关系(或直接前驱与直接后继关系)来描述。
前后件关系是数据元素之间的一个基本关系,但前后件关系所表示的实际意义随具体对象的不同而不同。
一般来说,数据元素之间的任何关系都可以用前后件关系来描述。
1数据的逻辑结构
数据结构是指反映数据元素之间的关系的数据元素集合的表示。
更通俗地说,数据结构是指带有结构的数据元素的集合。
所谓结构实际上就是指数据元素之间的前后件关系。
一个数据结构应包含以下两方面信息:
(1)表示数据元素的信息;
(2)表示各数据元素之间的前后件关系。
数据的逻辑结构是对数据元素之间的逻辑关系的描述。
它可以用一嘎数据元素的集合和定义在此集合中的若干关系来表示。
数据的逻辑结构包括集合、线性结构、树型结构和图形结构四种。
线性结构:
数据元素之间构成一种顺序的线性关系。
树型结构:
数据元素之间形成一种树型的关系。
数据的逻辑结构有两个要素:
一是数据元素的集合,通常记为D;
二是D上的关系,它反映了数据元素之间的前后件关系,通常记为R。
一个数据结构可以表示成B=(C,R)
其中B表示数据结构。
为了反映D中各元素之间的前后件关系,一般用二元组来表示。
例如,复数是一种数据结构,在计算机科学中,复数可取如下定义:
B=(C,R)
其中,C是含有两个实数的集合{c1,c2};
R是定义在集合C上的一种关系{<
c1,c2>
},其中有序偶{<
}表示c1是复数的实部,c2是复数的虚部。
2数据的存储结构
数据的逻辑结构在计算机存储空间中的存放形式,称为数据的存储结构(也称为数据的物理结构)。
由于数据元素在计算机存储空间中的位置关系可能与逻辑关系不同,因此,为了表示存放在计算机存储空间中的各数据元素之间的逻辑关系(即前后件关系),在数据的存储结构中,不仅要存放各数据元素的信息,还需要存放各数据元素之间的前后件关系的信息。
一种数据的逻辑结构根据需要可以表示成多种存储结构,常用的结构有顺序、链接、索引等存储结构而采用不同的存储结构,其数据处理的效率是不同的。
因此,在进行数据处理时,选择合适的存储结构是很重要的。
考点4数据结构的图形表示
数据结构除了用二元关系表示外,还可以直观地用图形表示。
在数据结构的图形表示中,对于数据集合D中的每一个数据元素用中间标有元素值的方框表示,一般称之为数据结点,并简称为结点;
为了进一步表示各数据元素之间的前后件关系,对于关系R中的每一个二元组,用一条有向线段从前件结点指向后件结点。
在数据结构中,没有前件的结点称为根结点;
没有后件的结点称为终端结点(也称为叶子结点)。
一个数据结构中的结点可能是在动态变化的。
根据需要或在处理过程中,可以在一个数据结构中增加一个新结点(称为插入运算),也可以删除数据结构中的某个结点(称为删除运算)。
插入与删除是对数据结构的两种基本运算。
除此之外,对数据结构的运算还有查找、分类、合并、分解、复制和修改等。
考点5线性结构与非线性结构
如果在一个数据结构中一个数据元素都没有,则称该数据结构为空的数据结构。
根据数据结构中各数据元素之间前后件关系的复杂程度,一般将数据结构分为两大类型:
线性结构与非线性结构。
非空数据结构满足:
(l)有且只有一个根结点;
(2)每一个结点最多有一个前件,也最多有一个后件。
则称该数据结构为线性结构。
线性结构又称为线性表。
一个线性表是n个数据元素的有限序列。
至于每个元素的具体含义,在不同的情况下各不相同,它可以是一个数或一个符号,也可以是一页书,甚至其他更复杂的信息。
如果一个数据结构不是线性结构,称之为非线性结构。
线性结构与非线性结构都可以是空的数据结构。
对于空的数据结构,如果对该数据结构的运算是按线性结构的规则来处理的,则属于线性结构;
否则属于非线性结构。
1.3线性表及顺序存储结构
考点6线性表的定义
线性表是n(n≥0)个元素构成的有限序列(a1,a2,…,an)。
表中的每一个数据元素,除了第一个外,有且只有一个前件,除了最后一个外,有且只有一个后件。
即线性表是一个空表,或可以表示为
(a1,a2,…,an)
其中ai(i=1,2,…,n)是属于数据对象的元素,通常也称其为线性表中的一个结点。
其中,每个元素可以简单到是一个字母或是一个数据,也可能是比较复杂的由多个数据项组成的。
在复杂的线性表中,由若干数据项组成的数据元素称为记录(record),而由多个记录构成的线性表又称为文件(file)。
在非空表中的每个数据元素都有一个确定的位置,如a1是第一个元素,an是最后一个数据元素,ai是第i个数据元素,称i为数据元素ai在线性表中的位序。
非空线性表有如下一些结构特征:
(1)有且只有一个根结点a1,它无前件;
(2)有且只有一个终端结点an,它无后件;
(3)除根结点与终端结点外,其他所有结点有且只有一个前件,也有且只有一个后件。
线性表中结点的个数n称为线性表的长度。
当n=0时称为空表。
考点7线性表的顺序存储结构
线性表的顺序表指的是用一组地址连续的存储单元依次存储线性表的数据元素。
线性表的顺序存储结构具备如下两个基本特征:
(l)线性表中的所有元素所占的存储空间是连续的;
(2)线性表中各数据元素在存储空间中是按逻辑顺序依次存放的。
假设线性表的每个元素需要占用k个存储单元,并以所占的存储位置ADR(ai+1)和第i个数据元素的存储位置ADR(ai)之间满足下列关系:
ADR(ai+1)=ADR(ai)+k
线性表第i个元素ai的存储位置为
ADR(ai)=ADR(a1)+(i-1)×
k
式中ADR(ai)是线性表的第一个数据元素a的存储位置,通常称做线性表的起始位置或基址。
线性表的这种表示称做线性表的顺序存储结构或顺序映像,这种存储结构的线性表为顺序表。
表中每一个元素的存储位置都和线性表的起始位置相差一个和数据元素在线性表中的位序成正比例的常数。
如图1-4所示。
由此只要确定了存储线性表的起始位置,线性表中任一数据元素都可以随机存取,所以线性表的顺序存储结构是一种随机存取的存储结构。
在程序设计语言中,通常定义一个一维数组来表示线性表的顺序存储空间。
在用一维数组存放线性表时,该一维数组的长度通常要定义得比线性表的实际长度大一些,以便对线性表进行各种运算,特别是插入运算。
在线性表的顺序存储结构下,可以对线性表做以下运算:
(l)在线性表的指定位置处加入一个新的元素(即线性表的插入);
(2)在线性表中删除指定的元素(即线性表的删除);
(3)在线性表中查找某个(或某些)特定的元素(即线性表的查找);
(4)对线性表中的元素进行整序(即线性表的排序);
(5)按要求将一个线性表分解成多个线性表(即线性表的分解);
(6)按要求将多个线性表合并成一个线性表(即线性表的合并);
(7)复制一个线性表(即线性表的复制);
(8)逆转一个线性表(即线性表的逆转)等。
考点8顺序表的插入运算
线性表的插入运算是指在表的第i(1≤i≤n+l)个位置上,插入一个新结点x,使长度为n的线性表
(a1,…,ai-1,ai,…,an)
变成长度为n+1的线性表
(a1,…,ai-1,x,ai,…,an)
现在分析算法的复杂度。
这里的问题规模是表的长度,设它的值为n。
该算法的时间主要花费在循环结点后移语句上,该语句的执行次数(即移动结点的次数)是n-i+1。
由此可看出,所需移动结点的次数不仅依赖于表的长度,而且还与插入位置有关。
当i=n+1时,由于循环变量的终值大于初值,结点后移语句将不进行;
这是最好情况,其时间复杂度O
(1);
当i=1时,结点后移语句,将循环执行n次,需移动表中所有结点,这是最坏情况,其时间复杂度为O(n)。
由于插入可能在表中任何位置上进行,因此需分析算法的平均复杂度。
在长度为n的线性表中第i个位置上插入一个结点,令Eis(n)表示移动结点的期望值(即移动的平均次数),则在第i个位置上插入一个结点的移动次数为n-i+1。
故
不失一般性,假设在表中任何位置(1≤i≤n+1)上插入结点的机会是均等的,则
p1=p2=p3=…=pn+1=1/(n+1)
因此,在等概率插入的情况下,
也就是说,在顺序表上做插入运算,平均要移动表上一半的结点。
当表长n较大时,算法的效率相当低。
虽然Eis(n)中n的的系数较小,但就数量级而言,它仍然是线性级的。
因此算法的平均时间复杂度为O(n)。
考点9顺序表的删除运算
线性表的删除运算是指将表的第i(1≤i≤n)个结点删除,使长度为n的线性表:
(a1,…,ai-1,ai,ai+1,…,an)
变成长度为n-l的线性表
(a1,…,ai-1,ai+1,…,an)
该算法的时间分析与插入算法相似,结点的移动次数也是由表长n和位置i决定。
若i=n,则由于循环变量的初值大于终值,前移语句将不执行,无需移动结点;
若i=1,则前移语句将循环执行n一1次,需移动表中除开始结点外的所有结点。
这两种情况下算法的时间复杂度分别为O
(1)和O(n)。
删除算法的平均性能分析与插入算法相似。
在长度为n的线性表中删除一个结点,令Ede(n)表示所需移动结点的平均次数,删除表中第i个结点的移动次数为n-i,故
式子中,pi表示删除表中第i个结点的概率。
在等概率的假设下,
p1=p2=p3=…=pn=1/n
由此可得:
即在顺序表上做删除运算,平均要移动表中约一半的结点,平均时间复杂度也是O(n)。
1.4栈和队列
考点10栈及其基本运算
1什么是栈
栈实际也是线性表,只不过是一种特殊的线性表。
栈(Stack)是只能在表的一端进行插入和删除运算配线性表,通常称插入、删除的这一端为栈顶(Top),另一端为栈底(Bottom)。
当表中没有元素时称为空栈(栈顶元素总是后被插入的元素,从而也是最先被删除的元素;
栈底元素总是最先被插入的元素,从而也是最后才能被删除的元素。
假设栈S=(al,a2,a3,…,an),则a1,称为栈底元素,an为栈顶元素。
栈中元素按a1,a2,a3,…,an的次序进栈,退栈的第一个元素应为栈顶元素。
换句话说,栈的修改是按先进后出的原则进行的。
因此,栈称为先进后出表(FILO,FirstInLastOut),或“后进先出”表(LIFO,LastInFirstOut),如图1-7所示。
2栈的顺序存储及其运算
(l)入栈运算:
入栈运算是指在栈顶位置插入一个新元素。
首先将栈顶指针加一(即top加1),然后将元素插入到栈顶指针指向的位置。
当栈顶指针已经指向存储空间的最后一个位置时,说明栈空间已满,不可能再进行入栈操作。
这种情况称为栈“上溢”错误。
如图1-8所示。
(2)退栈运算:
退栈是指取出栈顶元素并赋给一个指定的变量。
首先将栈顶元素(栈顶指针指向的元素)赋给一个指定的变量,然后将栈顶指针减一(即t叩减1)。
当栈顶指针为0时,说明栈空,不可进行退栈操作。
这种情况称为栈的“下溢”错误。
(3)读栈顶元素:
读栈顶元素是指将栈顶元素赋给一个指定的变量。
这个运算不删除栈顶元素,只是将它赋给一个变量,因此栈顶指针不会改变。
当栈顶指针为0时,说明栈空,读不到栈顶元素。
考点11队列及其基本运算
1什么是队列
队列(queue)是只允许在一端删除,在另一端插入的顺序表,允许删除的一端叫做队头(front),允许插入的一端叫做队尾(rear),
当队列中没有元素时称为空队列。
在空队列中依次加入元素a1,a2,…,an之后,a1是队头元素,an是队尾元素。
显然退出队列的次序也只能是a1,a2,…,an也就是说队列的修改是依先进先出的原则进行的。
因此队列亦称作先进先出(FIFO,FirstInFirstOut)的线性表,或后进后出(LILO,LastInLastOut)的线性表。
往队列队尾插入一个元素称为入队运算,从队列的排头删除一个元素称为退队运算,如图1-10所示。
一个队列币。
删除个儿素后的队列间插入元素E后的队列
2循环队列及其运算
在实际应用中,队列的顺序存储结构一般采用循环队列的形式。
所谓循环队列,就是将队列存储空间的最后一个位置绕到第一个位置,形成逻辑上的环状空间
在循环队列中,用队尾指针rear指向队列中的队尾元素,用排头指针front指向排头元素的前一个位置。
因此,从排头指针front指向的后一个位置直到队尾指针rear指向的位置之间所有的元素均为队列中的元素。
可以将向量空间想象为一个首尾相接的圆环,如图1-12所示,并称这种向量为循环向量,存储在其中的队列称为循环队列(CireularQueue)。
在循环队列中进行出队、入队操作时,头尾指针仍要加1,朝前移动。
只不过当头尾指针指向向量上界(Queuesize-l)时,其加1操作的结果是指向向量的下界0。
由于入队时尾指针向前追赶头指针,出队时头指针向前追赶尾指针,故队空和队满时头尾指针均相等。
因此,我们无法通过front=rear来判断队列“空”还是“满”。
在实际使用循环队列时,为了能区分队列满还是队列空,通常还需增加一个标志、,、值的定义如下:
当s=0时表示队列空;
当s=1时表示队列非空。
(l)入队运算
入队运算是指在循环队列的队尾加入一个新元素。
首先将队尾指针进一(即rear=rear+1),并当rear=m+l时置rear=1;
然后将新元素插入到队尾指针指向的位置。
当循环队列非空(s=l)且队尾指针等于队头指针时,说明循环队列已满,不能进行入队运算,这种情况称为“上溢”。
(2)退队运算
退队运算是指在循环队列的队头位置退出一个元素并赋给指定的变量。
首先将队头指针一进一(即from=front+1),并当front=m+1时,置front=1然后将排头指针指向的元素赋给指定的变量。
当循
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 计算机 二级 公共 基础知识