标签:保存 nod 搜索 收集 跳过 pil 方式 图算法 面向过程
65# 抽象数据类型与子程序 #
抽象数据类型(ADT):属性(数据和操作)明确地与特定实现分离的容器。
数据结构:一种抽象 数据类型中的复合数据域的实现。
容器(container): 存放和操作其他对象的对象。
栈和队列是抽象复合结构,二者经常被同时提及,栈是种抽象复合结构,只能从一端访问栈中的元素。可以在第一个位置插人元素,也可以删除第一个元素。 这种设计模拟了日常生活中的很多事情。会计师称它为LIFO.即后进先出(Last In First Out)的缩写。自助餐厅的餐具架就有这种属性:我们只能取顶上的碟子。当取走一个碟子后,下面的碟子就出现在了顶层。
另一种描述栈的访问行为的说法是删除的项总是在栈中时间最短的项目。从这个角度观察栈就更加抽象。插人操作没有任何约束;整个LIFO行为都体现在删除操作上。
栈的插入和删除操作有了个惯用语,插人操作叫作Push (推进),删除操作叫作Pop (弹出)。我们把项目推进栈,从栈中弹出项目。栈没有长度属性,所以没有返回栈中项目个数的操作。我们需要的是确定栈是否为空(Is Empty)的操作,因为当栈空的时候再弹出项目会出错。
队列也是种抽象结构,队列中的项目从一端人,从另端出。会计师称之为FIFO、即先进先出(Fist In First Out)的缩写。插入操作在队列的rear(尾部)进行,删除操作在队列的front(头部)进行。
另一种描述队列的访问行为的说法是删除的总是在队列中时间最长的项目。
列表有三个属性特征:项目是同构的,项目是线性的,列表是变长的。线性的意思是,每个项目除了第一个都有一个独特的组成部分在它之前,除了最后一个也都有一个独特的组成部分在它之前后。
数组是内嵌结构,,列表是抽象结构。
列表也可以被形象化为链式结构,链式结构以节点的概念为基础。
链式结构(linked structure):一个将数据项和找到下一项位置的信息保存到同一容器的实现方法。
任何节点的值都要大于它的左子树中的所有节点的值,并且要小于它的右子树中的所有节点的值。
列表、栈、队列和树都是可容纳元素的容器。用户根据特定的问题选择最合适的容器。不被纳人检索过程的算法是没有固定语义的:栈返回的元素是在其中停留时间最少的元素;队列返回的是在其中停留时间最长的元素。队列和树返回的信息都是被请求的。然而不同的是,在图中定义的算法可以解决实际的问题。首先我们来探讨创建一个图,然后讨论利用图可以解决的问题。
许多信息可以被呈现在图上:顶点、边和权值。让我们利用航班连接数据来把这些结构可视化为一张表。表8-3中的行和列标有城市的名字。单元格中的零代表从该行城市到该列城市不存在可以直达的航班。表格中的数值为从该行城市至该列城市的公里数。
创建-一个表格需要以下操作:
●在表格中添加一个顶点
●在表格中添加一条边
●在表格中添加一个权值
值参(value parameter):由调用单元传入实参的副本(写在留言板上)的形参。 引用参数(reference parameter):由调用单元传入实参的地址(卸载留言板上)的形参。
面向对象的设计方法是用叫作对象的独立实体生成解决方案的问题求解方法,对象由数据和处理数据的操作构成。面向对象设计的重点是对象以及它们在问题中的交互。一.旦收集到了问题中的所有对象,它们就能构成问题的解决方案。
我们提出的分解过程有四个阶段。 集体讨论(头脑风暴)是确定问题中的类的第个阶段。在过滤这个阶段中,将回顾集体讨论阶段确定的类,看哪些类是可以合并的以及还缺少哪些类。过滤阶段保留下来的类将在下一个阶段仔细研究。 场景阶段将确定每个类的行为。由于每个类只对自己的行为负责,所以我们称类的行为为责任。这个阶段探讨的是“如果....将会怎 么样”的问题,以确保所有的情况都被分析到。当每个类的责任都确定后,它们将被记录下来,同时记录的还有它们必须与之协作(交互)才能履行责任的类的名字。 最后是责任算法阶段,这个阶段将为列出的所有类的责任编写算法。CRC卡就是用来记录这一阶段的类信息的工具。
编译器(compiler):把用高级语言编写的程序翻译成机器码的程序。 解释器(interpreter):输入用高级语言编写的程序,指导计算机执行每个语句指定的动作的程序。 字节码(bytecode):编译Java源代码使用的标准机器语言。
在高级语言中,选择和迭代操作非常简单,但子程序和参数传递则较为复杂。
一个布尔表达式可以是:
迄今为止,在示例中,变量存放的都是数值。布尔变量是内存中的一一个地址,由存放true或false的标识符引用。
数据是表示信息的物理符号。在计算机内部,数据和指令都是二进制位的组合。计算机能够执行一条指令,是因为这条指令的地址被载人了程序计数器,而指令被载入了指令寄存器。被执行的位组合同样可以表示整数、实数、字符或布尔值,关键看计算机如何解释位组合。
大多数高级语言都固有四种数据类型,即整数、实数、字符和布尔型。
整数数据类型表示的是一个整数值的范围,这个范围由表示整数值的字节数决定。有些高级语言提供几种范围不同的整数类型,允许用户根据特定问题选择最适合的类型。
实数数据类型表示的是特定精度的数的范围,与整数数据类型一样,这个范围由表示实数值的字节数决定。许多高级语言有两种大小的实数。应用于实数的操作与应用于整数的一样。但在对实数应用关系运算符时要小心,因为实数通常不精确。
第3章介绍过,表示ASCII字符集中的字符需要-一个字节,表示Unicode字符集中的字符则需要两个字节。ASCII字符集包括英语字符,是Unicode字符集的子集。对字符进行算术运算是毫无意义的,许多强类型化的语言都不允许进行这种运算。但比较字符却是有意义的,所以可以对字符进行关系运算。在字符的关系运算中,“小于”和“大于”的意思是这个字符在字符集中“在.....之前” 和“在....之后”。例如,字符‘A’小于‘B‘,字符‘B’小于‘C‘,等等。字符‘1’小于字符‘2‘,‘2’小于‘3’,等等。如果要比较‘A’和“1’, 必须在使用的字符集中查找这两个字符间的关系。
布尔数据类型只有两个值——true和false。还可以为布尔变量指定一个布尔表达式。
整数、实数、字符和布尔型称为简单数据类型或原子数据类型,因为每个值都是独立的,不能再分割。上一章讨论了 复合数据类型,即由一组值构成的数据类型。字符串是一种具有复合数据类型的特征的数据类型,但通常被看作简单数据类型。
字符串是一个字符序列,在某些语言中这个序列通常被看作一个数据值。
在非强类型语言中,输入的格式决定了类型。如果输人出现在引号之间,则它被假定为一个字符串,并以字符串的形式存储。如果输人的是一个数字, 它将被存储为数字。
输出语句创建字符流。输出语句中列出的项目可以是文字值或变量名。文字值是直接在输出语句中写的数字或字符串(或任何语句)。一次处理一个将要输出的值,从而找到标识符或文字的类型。类型确定了如何解释位模式。如果该类型是字符串,则将字符写人输出流。如果该位模式为数字,则该数字将被转换为表示数字的字符,并将字符输出。
在强类型语言中,不管输人输出语句的语法或输人输出流在哪儿,处理的关键在于数据类型,数据类型确定字符是如何被转换为位模式(输人)以及如何被转换为字符(输出)。在非强类型语言中,输人的格式决定了位模式是如何转换的。
在任何控制语句中被执行或跳过的语句可以是简单的语句或块(一组语句),对于这些语句没有任何限制。事实上,被跳过或重复的语句可以包含一个控制结构。选择语句可以在循环结构中被嵌套。循环结构可以在选择语句中被嵌套。选择和循环语句可以在子程序中被嵌套,而子程序可以在循环或选择结构中被嵌套。
异步处理也叫作事件驱动处理。换句话说,这样的处理是被程序指令序列以外发生的事件所控制。
异步处理经常被用在Java和VB.NET中,但是很少被其他语言所使用。
从语法上来说,类像前面介绍的记录,它们都是异构复合数据类型。但记录通常被认为是被动结构,只是近年来才采用子程序作为域。而类则是主动结构,一直都把子程序 用作域。操作类的数据域的唯一方式是通过类中定义的方法(子程序)。
算法声明类的对象只能通过类的子程序(称为方法)访问类的域。
默认情况下,类中的域是私有的,也就是说,除非一个类的某 个域被标识为public (公有),否则任何其他对象都不能访问这个类的对象的域(无论是数据还是方法)。如果一个类想让其他类的对象调用自己的方法,就必须明确地声明这个方法是public的。Person 类中的方法被标记为public,以便用程序可以调用。
继承是面向对象语言的一种属性, 即一个类可以继承另一个类的数据和方法。这种关系是一种is-a关系。超类是被继承的类,派生类是继承的类。类构成了继承的体系结构。在这种体系结构中,所处的层次越低,对象越专门化。下级的类会继承其父类的所有行为和数据。
继承通过允许应用程序使用已经被测试过的类和从一一个类中继 承应用所需的属性来促进重用。其他必要的属性和方法可以在之后加人派生类中。
假设Person类和Student类都具有名为Print和Initialize的方法。在Person类中,这个方法将输出Person类中定义的地址,在Student类中,该方法则输出Student类中定义的地址。这两个方法名字相同,但实现不同。程序设计语言处理这种明显二义性的能力叫作多态性。语言如何知道调用单元调用的是哪个Print方法还是Initialize方法呢?调用单元将把类的方法应用于类的一一个实例,应用这个方法的对象的类可以确定使用的是Print 或Initialize的哪个版本。
在面向过程的版本中,列表被呈现为传递给子程序的记录,以便子程序可以对其操作。操作它的数据结构和子程序是用户程序的一部分。
在面向对象的版本中,类对象的实现通过封装实现对用户的隐藏。
2019-2020-1学期 20192410《网络空间安全专业导论》第四周学习总结
标签:保存 nod 搜索 收集 跳过 pil 方式 图算法 面向过程
原文地址:https://www.cnblogs.com/dkyspurs/p/11768195.html