算法合集之《数据结构的在程序设计中的应用》

上传人:hs****ma 文档编号:504395912 上传时间:2022-08-23 格式:DOC 页数:28 大小:122.50KB
返回 下载 相关 举报
算法合集之《数据结构的在程序设计中的应用》_第1页
第1页 / 共28页
算法合集之《数据结构的在程序设计中的应用》_第2页
第2页 / 共28页
算法合集之《数据结构的在程序设计中的应用》_第3页
第3页 / 共28页
算法合集之《数据结构的在程序设计中的应用》_第4页
第4页 / 共28页
算法合集之《数据结构的在程序设计中的应用》_第5页
第5页 / 共28页
点击查看更多>>
资源描述

《算法合集之《数据结构的在程序设计中的应用》》由会员分享,可在线阅读,更多相关《算法合集之《数据结构的在程序设计中的应用》(28页珍藏版)》请在金锄头文库上搜索。

1、数据结构的在程序设计中的应用长沙市一中 肖洲【关键字】 逻辑结构 存储结构 算法优化【摘要】 数据结构作为程序设计的基础,其对算法效率的影响必然是不可忽视的。本文就如何合理选择数据结构来优化算法这一问题,对选择数据结构的原则和方法进行了一些探讨。首先对数据逻辑结构的重要性进行了分析,提出了选择逻辑结构的两个基本原则;接着又比较了顺序和链式两种存储结构的优点和缺点,并讨论了选择数据存储结构的方法;最后本文从选择数据结构的的另一角度出发,进一步探讨了如何将多种数据结构进行结合的方法。在讨论方法的同时,本文还结合实际,选用了一些较具有代表性的信息学竞赛试题举例进行了分析【正文】一、引论“数据结构算法

2、程序”,这就说明程序设计的实质就是对确定的问题选择一种合适的数据结构,加上设计一种好的算法。由此可见,数据结构在程序设计中有着十分重要的地位。数据结构是相互之间存在一种或多种特定关系的数据元素的集合。因为这其中的“关系”,指的是数据元素之间的逻辑关系,因此数据结构又称为数据的逻辑结构。而相对于逻辑结构这个比较抽象的概念,我们将数据结构在计算机中的表示又称为数据的存储结构。建立问题的数学模型,进而设计问题的算法,直至编出程序并进行调试通过,这就是我们解决信息学问题的一般步骤。我们要建立问题的数学模型,必须首先找出问题中各对象之间的关系,也就是确定所使用的逻辑结构;同时,设计算法和程序实现的过程,

3、必须确定如何实现对各个对象的操作,而操作的方法是决定于数据所采用的存储结构的。因此,数据逻辑结构和存储结构的好坏,将直接影响到程序的效率。二、选择合理的逻辑结构在程序设计中,逻辑结构的选用就是要分析题目中的数据元素之间的关系,并根据这些特定关系来选用合适的逻辑结构以实现对问题的数学描述,进一步解决问题。逻辑结构实际上是用数学的方法来描述问题中所涉及的操作对象及对象之间的关系,将操作对象抽象为数学元素,将对象之间的复杂关系用数学语言描述出来。根据数据元素之间关系的不同特性,通常有以下四种基本逻辑结构:集合、线性结构、树形结构、图状(网状)结构。这四种结构中,除了集合中的数据元素之间只有“同属于一

4、个集合”的关系外,其它三种结构数据元素之间分别为“一对一”、“一对多”、“多对多”的关系。因此,在选择逻辑结构之前,我们应首先把题目中的操作对象和对象之间的关系分析清楚,然后再根据这些关系的特点来合理的选用逻辑结构。尤其是在某些复杂的问题中,数据之间的关系相当复杂,且选用不同逻辑结构都可以解决这一问题,但选用不同逻辑结构实现的算法效率大不一样。对于这一类问题,我们应采用怎样的标准对逻辑结构进行选择呢?下文将探讨选择合理逻辑结构应充分考虑的两个因素。一、 充分利用“可直接使用”的信息。首先,我们这里所讲的“信息”,指的是元素与元素之间的关系。对于待处理的信息,大致可分为“可直接使用”和“不可直接

5、使用”两类。对于“可直接使用”的信息,我们使用时十分方便,只需直接拿来就可以了。而对于“不可直接使用”的这一类,我们也可以通过某些间接的方式,使之成为可以使用的信息,但其中转化的过程显然是比较浪费时间的。由此可见,我们所需要的是尽量多的“可直接使用”的信息。这样的信息越多,算法的效率就会越高。对于不同的逻辑结构,其包含的信息是不同的,算法对信息的利用也会出现不同的复杂程度。因此,要使算法能够充分利用“可直接使用”的信息,而避免算法在信息由“不可直接使用”向“可直接使用”的转化过程中浪费过多的时间,我们必然需要采用一种合理的逻辑结构,使其包含更多“可直接使用”的信息。问题一 IOI99的隐藏的码

6、字。问题描述问题中给出了一些码字和一个文本,要求编程找出文本中包含这些码字的所有项目,并将找出的项目组成一个最优的“答案”,使得答案中各项目所包含的码字长度总和最大。每一个项目包括一个码字,以及该码字在文本中的一个覆盖序列(如abcadc就是码字abac的一个覆盖序列),并且覆盖序列的长度不超过1000。同时,“答案”要求其中每个项目的覆盖序列互相没有重叠。问题分析对于此题,一种较容易得出的基本算法是:对覆盖序列在文本中的终止位置进行循环,再判断包含了哪些码字,找出所有项目,并最后使用动态规划的方法将项目组成最优的“答案”。算法的其它方面我们暂且不做考虑,而先对问题所采用的逻辑结构进行选择。如

7、果我们采用线性的逻辑结构(如循环队列),那么我们在判断是否包含某个码字t时,所用的方法为:初始时用指针p指向终止位置,接着通过p的不断前移,依次找出码字t从尾到头的各个字母。例如码字为“ABDCAB”,而文本图1-1,终止位置为最右边的箭头符号,每个箭头代表依次找到的码字的各个字母。指针p的移动方向 A B D C A BCDACBDCADCDBADCCBAD图1-1由于题目规定码字的覆盖序列长度不超过1000,所以进行这样的一次是否包含的判断,其复杂度为O(1000)。由于码字t中相邻两字母在文本中的位置,并非只有相邻(如图1-1中的D和C)这一种关系,中间还可能间隔了许多的字母(如图1-1

8、中C和A就间隔了2个字母),而线性结构中拥有的信息,仅仅只存在于相邻的两元素之间。通过这样简单的信息来寻找码字的某一个字母,其效率显然不高。如果我们建立一个有向图,其中顶点i(即文本的第i位)用52条弧分别连接a.z,A.Z这52个字母在i位以前最后出现的位置(如图1-2的连接方式),我们要寻找码字中某个字母的前一个字母,就可以直接利用已连接的边,而不需用枚举的方法。我们也可以把问题看为:从有向图的一个顶点出发,寻找一条长度为length(t)-1的路径,并且路径中经过的顶点,按照码字t中的字母有序。CDACBDCADCDBADCCBAD图1-2通过计算,用图进行记录在空间上完全可以承受(记录

9、1000个点52条弧4字节的长整型=200k左右)。在时间上,由于可以充分利用第i位和第i+1位弧的连接方式变化不大这一点(如图1-2所示,第i位和第i+1位只有一条弧的指向发生了变化,即第i+1位将其中一条弧指向了第i位),所以要对图中的弧进行记录,只需对弧的指向进行整体赋值,并改变其中的某一条弧即可。因此,我们通过采用图的逻辑结构,使得寻找字母的效率大大提高,其判断的复杂度为O(length(t),最坏为O(100),比原来方法的判断效率提高了10倍。(附程序codes.pas)对于这个例子,虽然用线性的数据结构也可以解决,但由于判断的特殊性,每次需要的信息并不能从相邻的元素中找到,而线性

10、结构中只有相邻元素之间存在关系的这一点,就成为了一个很明显的缺点。因此,问题一线性结构中的信息,就属于“不可直接使用”的信息。相对而言,图的结构就正好满足了我们的需要,将所有可能产生关系的点都用弧连接起来,使我们可以利用弧的关系,高效地进行判断寻找的过程。虽然图的结构更加复杂,但却将“不可直接使用”的信息,转化成为了“可直接使用”的信息,算法效率的提高,自然在情理之中。二、 不记录“无用”信息。从问题一中我们看到,由于图结构的信息量大,所以其中的信息基本上都是“可用”的。但是,这并不表示我们就一定要使用图的结构。在某些情况下,图结构中的“可用”信息,是有些多余的。信息都“可用”自然是好事,但倘

11、若其中“无用”(不需要)的信息太多,就只会增加我们思考分析和处理问题时的复杂程度,反而不利于我们解决问题了。问题二 湖南省1997年组队赛的乘船问题问题描述有N个人需要乘船,而每船最多只能载两人,且必须同名或同姓。求最少需要多少条船。问题分析看到这道题,很多人都会想到图的数据结构:将N个人看作无向图的N个点,凡同名或同姓的人之间都连上边。要满足用船最少的条件,就是需要尽量多的两人共乘一条船,表现在图中就是要用最少的边完成对所有顶点的覆盖。这就正好对应了图论的典型问题:求最小边的覆盖。所用的算法为“求任意图最大匹配”的算法。使用“求任意图最大匹配”的算法比较复杂(要用到扩展交错树,对花的收缩等等

12、),效率也不是很高。因此,我们必须寻找一个更简单高效的方法。首先,由于图中任两个连通分量都是相对独立的,也就是说任一条匹配边的两顶点,都只属于同一个连通分量。因此,我们可以对每个连通分量分别进行处理,而不会影响最终的结果。同时,我们还可以对需要船只s的下限进行估计:对于一个包含Pi个顶点的连通分量,其最小覆盖边数显然为Pi/2。若图中共有L个连通分量,则s=Pi/2(1=i=L)。 然后,我们通过多次尝试,可得出一个猜想:实际需要的覆盖边数完全等于我们求出的下限Pi/2(1=i0)表示lcp,i-1的左儿子,显然lcp,i与p是同姓的。假设存在某个点q,满足qs且qT。由于s是有限集合,因而必然存在某个lcp,k无左儿子。则我们可以令lcp,k+1=q,所以qT,与假设qT相矛盾。所以假设不成立,原命题得证。由引理2.1的证明方法,我们同理可证引理2.2。【引理2.2】若二叉树T中包含了某个结点p,那么连通分量中所有与p同名的点一定都在T中。有了上面的两个引理,我们就不难得出下面的定理了。【定理一】以连通分量中的任一点p作为根结点的二叉树,必然能够包含连通分量中的所有顶点。证明:由引理2.1和引理2.

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 中学教育 > 试题/考题 > 初中试题/考题

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号