《算法与数据结构-算法与流程图.ppt》由会员分享,可在线阅读,更多相关《算法与数据结构-算法与流程图.ppt(38页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、算法与流程图算法与流程图第章第章图与网的定义和术语目标目标q数据结构与算法qC程序的基本结构q用流程图描述算法q用C语言描述算法图与网的定义和术语2引例:引例:首先分析学籍档案类问题。设一个班级有50个学生,这个班级的学籍表如表所示。我们可以把表中每个学生的信息看成一个记录,表中的每个记录又由7个数据项组成。该学籍表由50个记录组成,记录之间是一种顺序关系。这种表通常称为线性表,数据之间的逻辑结构称为线性结构,其主要操作有检索、查找、插入或删除等。学学 籍籍 表表序号学号姓名性别英语数学物理0120030301李明男8691800220030302马琳男7683855020030350刘薇薇女
2、889390数据结构的基本概念和术语数据结构的基本概念和术语6-1图与网的定义和术语3 又如,对于学院的行政机构,可以把该学院的名称看成树根,把下设的若干个系看成它的树枝中间结点,把每个系分出的若干专业方向看成树叶,这样就形成一个树型结构,如下图所示。树中的每个结点可以包含较多的信息,结点之间的关系不再是顺序的,而是分层、分叉的结构。树型结构的主要操作有遍历、查找、插入或删除等。数据结构的基本概念和术语数据结构的基本概念和术语6-2图 专业设置图与网的定义和术语4 最后分析交通问题。如果把若干个城镇看成若干个顶点,再把城镇之间的道路看成边,它们可以构成一个网状的图,这种关系称为图型结构或网状结
3、构。这是一个图论方面的问题。交通图的存储和管理确实不属于单纯的数值计算问题,而是一种非数值的信息处理问题。数据结构的基本概念和术语数据结构的基本概念和术语6-3图 交通示意图图与网的定义和术语5一般来说,数据结构研究的是一类普通数据的表示及其相关的运算操作。数据结构是一门主要研究怎样合理地组织数据,建立合适的数据结构,提高计算机执行程序所用的时间效率和空间效率的学科。数据结构的基本概念和术语数据结构的基本概念和术语6-46数据(Data)-描述客观事物的数字、字符以及所有能够输入到计算机中并被计算机处理的信息的总称。数据元素(Data Element)-是数据的基本单位,在计算机中通常作为一个
4、整体进行考虑和处理。数据元素除了可以是一个数字或一个字符串以外,它也可以由一个或多个数据项组成。数据项(Data Item)-是有独立含义的数据的最小单位,有时也称为字段(Field)。数据结构的基本概念和术语数据结构的基本概念和术语6-5图与网的定义和术语7 数据对象(Data Object)-是具有相同性质的数据元素的集合,是数据的一个子集。例如,整数数据对象是集合N=0,1,2,,字母字符数据对象是集合C=A,B,Z。本节的学籍表也可看成一个数据对象。数据结构(Data Structure)-是带有结构的数据元素的集合,它是指数据元素之间的相互关系,即数据的组织形式、存储形式以及定义在它
5、们之上的一组运算。不论是存储结构的设计,还是运算的算法设计,都必须考虑存储空间的开销和运行时间的效率。数据结构的基本概念和术语数据结构的基本概念和术语6-6图与网的定义和术语8 在解决实际问题时,当确定了数据结构之后,需进一步研究与之相关的一组操作(也称运算),主要有插入、删除、排序、查找等。为了实现某种操作(如查找),常常需要设计一种算法。算法(Algorithm)是对特定问题求解步骤的一种描述,是指令的有限序列。描述算法需要一种语言,可以是自然语言、数学语言或者是某种计算机语言。什么是算法什么是算法图与网的定义和术语9 (1)输入:一个算法应该有零个、一个或多个输入。(2)有穷性:一个算法
6、必须在执行有穷步骤之后正常结束,而不能形成无穷循环。(3)确定性:算法中的每一条指令必须有确切的含义,不能产生多义性。(4)可行性:算法中的每一个指令必须是切实可执行的,即原则上可以通过已经实现的基本运算执行有限次来实现。(5)输出:一个算法应该至少有一个输出,这些输出是同输入有某种特定关系的量。算法的特性算法的特性图与网的定义和术语10算法设计要求算法设计要求q正确性程序对于典型、苛刻而带有刁难性的几组输入数据能够得出满足规格说明要求的结果q可读性q健壮性当输入数据非法时,能够适当地做出反应或者进行处理,而不会产生莫名其妙的结果q效率与低存储量需求图与网的定义和术语11算法实现算法实现q文档
7、q伪代码qN-S图q流程图q代码q自然语言12算法例子算法例子q从键盘中输入100个整数,对其中的正整数进行累加,最后输出结果。图与网的定义和术语13算法描述(自然语言)算法描述(自然语言)1、输入一个数;2、如果该数0,累加它;3、如果100个数没有输入完,转步骤1;4、输入完100个数后,输出累加和。图与网的定义和术语14算法描述(流程图)算法描述(流程图)15算法描述(算法描述(N-S流程图)流程图)图与网的定义和术语16算法的算法的C语句实现语句实现图与网的定义和术语17流程图符号流程图符号符号说明程序的开始或结束计算步骤输入/输出指令判断和分支连接符流程线18C程序的基本结构程序的基
8、本结构q顺序结构q选择结构q循环结构图与网的定义和术语19顺序结构顺序结构3-1q顺序结构的流程图:图与网的定义和术语20顺序结构顺序结构3-221顺序结构顺序结构3-3图与网的定义和术语22选择结构选择结构2-1q选择结构的流程图:图与网的定义和术语23选择结构选择结构2-224循环结构循环结构2-1q循环结构的流程图:图与网的定义和术语25循环结构循环结构2-2q从键盘输入9 个数,找出最大值图与网的定义和术语26流程图的画法流程图的画法演示使用visio画流程图27 如何选择描述数据结构和算法的语言是十分重要的问题。在Windows环境下涌现出一系列功能强大、面向对象的描述工具,如Vis
9、ual C+,Borland C+,Visual Basic,Visual FoxPro等。近年来在计算机科学研究、系统开发、教学以及应用开发中,C语言的使用越来越广泛。因此,我们可以采用C语言进行算法描述。为了能够简明扼要地描述算法,突出算法的思路,一般有以下约定:用用C语言实现算法语言实现算法5-1图与网的定义和术语28 (1)问题的规模尺寸用MAXSIZE表示,约定在宏定义中已经预先定义过,例如:#define MAXSIZE 100 (2)数据元素的类型一般写成ELEMTP,可以认为在宏定义中预先定义过,例如:#define ELEMTP int 在上机实验时根据需要,可临时用其他某个
10、具体的类型标识符来代替。用用C语言实现算法语言实现算法5-229 (3)一个算法要以函数形式给出:类型标识符 函数名(带类型说明的形参表)语句组例如:int add(int a,int b)int c;c=a+b;return(c);除了形参类型说明放在圆括号中之外,在描述算法的函数中其他变量的类型说明一般省略不写,这样使算法的处理过程更加突出明了。用用C语言实现算法语言实现算法5-330 (4)关于数据存储结构的类型定义以及全局变量的说明等均应在写算法之前进行说明。下面的例子给出了书写算法的一般步骤。例1.1 有n个整数,将它们按由大到小的顺序排序,并且输出。分析:n个数据的逻辑结构是线性表
11、(a1,a2,a3,an);选用一维数组作存储结构。用用C语言实现算法语言实现算法5-431用用C语言实现算法语言实现算法5-5/*数组a的数据由主函数提供*/32著名的计算机科学家N.沃思提出了一个有名的公式:算法+数据结构=程序。由此可见,数据结构和算法是程序的两大要素,二者相辅相成,缺一不可。一种数据结构的优劣是在实现其各种运算的算法中体现的。对数据结构的分析实质上也就是对实现其多种运算的算法的分析。评价一个算法应从四个方面进行:正确性、简单性、运行时间、占用空间。但主要看这个算法所要占用机器资源的多少。而在这些资源中时间和空间是两个最主要的方面,因此算法分析中最关心的也就是算法所需的时
12、间代价和空间代价。算法分析算法分析4-133 1.空间空间 所谓算法的空间代价(或称空间复杂性),是指当问题的规模以某种单位由1增至n时,解决该问题的算法实现所占用的空间也以某种单位由1增至f(n),并称该算法的空间代价是f(n)。算法分析算法分析4-234 2.时间时间 (1)语句频度(Frequency Count):指的是在一个算法中该语句重复执行的次数。(2)算法的渐近时间复杂度(Asymptotic Time Complexity):算法中基本操作重复执行的次数依据算法中最大语句频度来估算,它是问题规模n的某个函数f(n),算法的时间量度记作T(n)=O(f(n),表示随着问题规模n
13、的增大,算法执行时间的增长率和f(n)的增长率相同,称作算法的渐近时间复杂度,简称时间复杂度。时间复杂度往往不是精确的执行次数,而是估算的数量级。它着重体现的是随着问题规模的增大,算法执行时间增长的变化趋势。算法分析算法分析4-335例如,在下列三个程序段中:(a)x=x+1;(b)for(i=1;i=n;i+)x=x+1;(c)for(j=1;j=n;j+)for(k=1;k=n;k+)x=x+1;语句x=x+1的频度分别为1、n和 ,则(a)、(b)、(c)的时间复杂度分别是O(1)、O(n)、O()。由此可见,随着问题规模的增大,其时间消耗也在增大。算法分析算法分析4-4:常用算法实现与分析:常用算法实现与分析36结构化程序设计基本要求结构化程序设计基本要求q自顶向下,模块化设计q使用三种基本结构构造程序q程序书写规范,切勿随心所欲q清晰第一,效率第二思路清晰书写清晰(变量名、函数、注解等)书写注意缩进37总结总结q算法和数据结构q用流程图描述算法q用C语言描术算法38
限制150内