版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
第四章
树
4.3抽象数据类型
学习目标
抽象数据类型
数据类型与抽象数据类型抽象数据类型的应用
数据类型与抽象数据类型
数据类型是指一组性质相同的值的集合及定义在此集合上的一些操作的总称。·数据类型的概念·基本数据类型
整型、实型、布尔型、列表、字符串、字典·结构数据类型
抽象数据类型(类)
如python语言中的语句:A=11.4#定义浮点数变量A并赋值C=A+5#定义浮点数变量C并通过表达式赋值
抽象数据类型
数据类型与抽象数据类型抽象数据类型(ADT)是指一个数学模型及定义在该模型上的一组操作。
·抽象数据类型的概念抽象是一种思考问题的方式,它隐藏了繁杂的细节,只保留实现目标所必须的信息,实现抽象化后便于实现功能,提高模块独立性。程序语言的一个内置类型就可以看作是一个抽象数据类型,如整型(int)就是一个抽象数据类型,在整型对象的内部提供了一组操作可供编程者使用,每个操作都有明确的抽象意义,如“+”、“—”等。
抽象数据类型
字符串数据类型整型数据类型数据类型字符串对象操作求串长度取子串整型对象操作求和求余数数据结构具体操作抽象数据类型法师--甄姬人物外貌:形象,衣服等人物皮肤人物符文人物特征人物的移动:左右,上下,闪现,有无鞋子等人物施放技能:动画,伤害量等
抽象数据类型
数据类型与抽象数据类型例如:
在王者荣耀中,游戏人物的设定,一般都用抽象数据类型来定义人物对象。
因为所有的人物都符合几个特征:人物形象
人物的符文
人物的移动
人物有三个技能和被动
人物施放技能
人物技能的伤害量
抽象数据类型
数据类型与抽象数据类型·抽象数据类型的标准格式:ADT抽象数据类型名:Data
数据元素之间逻辑关系的定义Operation
操作1
初始条件
操作结果描述
操作2......
操作n......endADT
抽象数据类型
数据类型与抽象数据类型·抽象数据类型的标准格式:ADT抽象数据类型名:Data
数据元素之间逻辑关系的定义Operation
操作1
初始条件
操作结果描述
操作2......
操作n......endADT
抽象数据类型
数据类型与抽象数据类型·抽象数据类型(链表节点)##定义一个链表节点的抽象类classNode(
):
#初始化链表节点为空def__init__(self,value,next=None):self._value=valueself._next=next
#取当前节点的数值defgetValue(self):returnself._valueADT类型:class抽象数据类型名:Node初始化条件:__init__函数操作:getValue函数
抽象数据类型
数据类型与抽象数据类型·抽象数据类型列表,字符串,队列,树等都是抽象数据类型。列表:ADTList:List(self)#创建一个新表is_empty(self)#判断self是否为一个空表len(self)#返回表的长度append(self,elem)#在表尾插入元素elem
insert(self,elem,i)#在表的第i个位置插入元素elemdel(self,i)#删除第i个元素
抽象数据类型
数据类型与抽象数据类型·抽象数据类型列表,字符串,队列,树等都是抽象数据类型。字符串:ADTString:String(self,sseq)is_empty(self)len(self)char(self,index)substr(self,a,b)match(self,string)#基于字符串序列sseq建立一个字符串#判断字符串是否空串#取字符串的长度#取得字符串中位置index的字符#取得字符串中[a,b]的字串,左闭右开区间#查找字符串string在本字符串中第一次出现的位置现有一字符串对象str,若要获取字符串[a,b](左闭右闭)区间内的字串,正确的调用方式为______.substr(str,a,b+1)
抽象数据类型
数据类型与抽象数据类型·抽象数据类型列表,字符串,队列,树等都是抽象数据类型。#创建空队列#判断队列是否为空,空时返回True,否则返回False#将元素elem加入队列,即入队#出队#查看队列里最早进入的元素,不删除队列:ADTQueue:
Queue(self)is_empty(self)
enqueue(self,elem)
dequeue(self)peek(self)
抽象数据类型
数据类型与抽象数据类型·抽象数据类型列表,字符串,队列,树等都是抽象数据类型。#创建空栈#判断栈是否为空,空时返回True,否则返回False#将元素elem加入栈,即入栈#出栈#查看栈顶元素,不删除栈:ADTStack:
Stack(self)is_empty(self)
push(self,elem)
pop(self)peek(self)
抽象数据类型
数据类型与抽象数据类型·抽象数据类型的作用程序结构清晰、层次分明,便于程序正确性的证明和复杂性的分析。因为模块化的特点,便于改正错误的代码,利于维护系统。抽象数据类型的表示和实现利于封装,便于代码的移植和重用。使得算法设计和数据结构设计分开,降低了程序的复杂性,利于编写代码实现的可靠性。使得数据结构可自由选择,给了算法的优化空间,提高了程序运行的效率。二叉树Python代码实现classNode:#建立二叉树
def
__init__(self,value=None,left=None,right=None):self.value=value
self.left=left#左子树
self.right=right#右子树二叉树Python代码实现root=Node('A',Node('B',Node('D'),Node('E')),Node('C',rigt=Node('F',Node('G'))))print("前序遍历:")preTraverse(root)print("中序遍历:")midTraverse(root)print("后序遍历:")afterTraverse(root)
if
__name__=='__main__’:二叉树Python代码实现defpreTraverse(root):#前序遍历ifroot==None: returnprint(____________)preTraverse(_____________)preTraverse(______________)defmidTraverse(root):#中序遍历
ifroot==None:returnmidTraverse(root.left)print(root.value)midTraverse(root.right)defafterTraverse(root):#后序遍历
ifroot==None:returnafterTraverse(root.left)afterTraverse(root.right)print(root.value)root.valueroot.leftroot.rightifroot==None:
returnpr
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 永州师范高等专科学校《录音艺术与声音剪辑》2024-2025学年第二学期期末试卷
- 流动宴席内部管理制度
- 海尔内部奖罚制度
- 海边景区内部管理制度
- 煤矿内部用电管理制度
- 煤矿运输区内部管理制度
- 环保纠纷内部处置制度
- 甲方人员内部管理制度
- 监理内部考核投诉制度
- 科室内部审计制度
- 贸易公司考核制度范本
- 平安启航 筑梦新学期2026年大学开学安全教育第一课
- 高压电工实操模拟考试题库附答案
- 2026年内蒙古电子信息职业技术学院单招职业技能测试题库附参考答案详解(a卷)
- 2026年九江职业大学单招职业适应性测试题库带答案详解(夺分金卷)
- 2025年健康管理师三级考试重点复习题及答案
- 北森测评题库及答案2026
- 2026年苏州市职业大学单招职业技能测试模拟测试卷附答案
- 桥梁检测评定与加固技术课件 第2章 桥梁结构病害分析
- 2025-2026学年冀教版七年级英语上册(全册)知识点梳理归纳
- 消防自动报警系统培训
评论
0/150
提交评论