数据结构课件第01章.ppt
《数据结构课件第01章.ppt》由会员分享,可在线阅读,更多相关《数据结构课件第01章.ppt(48页珍藏版)》请在三一办公上搜索。
1、数据结构(C语言版)Data Structure,主讲教师马宁 计算机科学学院软件工程教研室,学习的直接收益,编程基础计算机专业考研课程计算机等级考试课程软件资格与水平考试课程进入优秀企业的敲门砖 盖茨说:学通了这本书(程序设计技巧,共三卷,其中第一卷主要为数据结构)来找我吧!,请同学们重视本课程的学习。,总学时:64 学时讲课学时:48 学时实验学时:16 学时 教材:数据结构(C语言版)严蔚敏、吴伟民-清华大学出版社,课程安排,参考书目,计算机及软件技术丛书 现代计算机常用数据结构和算法 潘金贵 编著 南京大学出版社数据结构习题与解析(C语言篇)修订版 李春葆 主编 计算机专业教学辅导丛书
2、 清华大学出版社,程序设计课程与数据结构课程的关系,程序设计强调程序设计的基本概念和做法,如:数据类型与表达式程序流程控制子程序递归数据抽象,等数据结构强调程序设计思想和技术的典型应用,如:线性表、栈、队列检索、排序图、树,等两者的内容又有交叉,本课程的体系结构,第一章 绪论 介绍数据、数据结构和抽象数据类型的概念。第二章 第七章 基本数据结构 从抽象数据类型的角度,分别讨论线性表、栈和队列、串、数组和广义表、树、图等基本数据结构及其应用。,1.1 数据结构学科的研究对象什么是程序、软件?N.沃思(Niklaus Wirth)教授提出:程序=算法+数据结构 以上公式说明了如下两个问题:(1)数
3、据上的算法决定如何构造和组织数据(算法数据结构)(2)算法的选择依赖于作为基础的数据结构(数据结构算法)软件=程序+文档(软件工程的观点),第一章 绪论,2.电子计算机的主要用途早期:主要用于数值计算。后来:应用逐渐扩大到非数值计算领域(能处理多种复杂的具有一定结构关系的数据)。数据复杂数据结构,3.计算机解决问题的一般步骤 数学模型算法程序(1)数值计算数学模型选择计算机语言编出程序测试最终解答。数值计算的关键是:如何得出数学模型(方程)?程序设计人员比较关注程序设计的技巧。(2)非数值计算问题数据元素之间的相互关系一般无法用数学方程加以描述。,例1、电话号码查询问题 查找:给出一个姓名,如
4、果存在,打印此人的电话号码;如果不存在,报告没有这个人的标志。(1)按顺序存储方式:须遍历表(2)按姓氏索引方式:索引要写出好的查找算法,取决于这张表的结构及存储方式。电话号码表的结构和存储方式决定了查找(算法)的效率。,4.非数值计算问题举例,书目文件,例2 书目自动检索系统,例3 人机对奕问题,例4 多叉路口交通灯管理问题,求解非数值计算的问题 主要考虑的是设计出合适的数据结构及相应的算法。即:首先要考虑对相关的各种信息如何表示、组织和存储?数据结构的研究对象是:非数值计算的程序设计问题中计算机的操作对象以及它们之间的关系和操作。,5.数据结构课程的形成和发展形成阶段:60年代初期,“数据
5、结构”有关的内容散见于操作系统、编译原理和表处理语言等课程。1968年,“数据结构”被列入美国一些大学计算机科学系的教学计划。发展阶段:数据结构的概念不断扩充,包括了网络、集合代数论、关系等“离散数学结构”的内容。70年代后期,我国高校陆续开设该课程。,6.数据结构课程所处的地位,1.2 基本概念和术语1.数据(Data):是对信息的一种符号表示。在计算机科学中是指所有能输入到计算机中并被计算机程序处理的符号的总称。2.数据元素(Data Element):是数据的基本单位,在计算机程序中通常作为一个整体进行考虑和处理。一个数据元素可由若干个数据项组成。数据项是数据的不可分割的最小单位。3.数
6、据对象(Data Object):是性质相同的数据元素的集合,是数据的一个子集。,4.数据类型(Data Type):在一种程序设计语言中,变量所具有的数据种类。例1、在FORTRAN语言中,变量的数据类型有整型、实型、和复数型 例2、在C语言中数据类型:基本类型、指针类型、空类型和结构类型其中,基本类型包括整型、浮点型、字符型和枚举类型,5.抽象数据类型(Abstract Data Type简称ADT)抽象数据类型是用户在数据类型基础上新定义的数据类型抽象数据类型定义包括数据组成和对数据的处理操作抽象数据类型是数据和数据的使用者的一个接口抽象数据类型的三元组表示(D,S,P)D:数据对象 S
7、:D上的关系集 P:对D的基本操作ADT的作用结构与用户无关,提高代码的复用率,抽象数据类型的定义:包括数据对象定义、数据关系定义和基本操作定义,书写格式为:ADT 抽象数据类型名 数据对象:数据对象的定义 数据关系:数据逻辑关系的定义 基本操作:基本操作的定义 P 8 倒数7行 ADT 抽象数据类型名(P9 例 1-6 伪码描述)P 8 倒数4行,C+的引用类型,引用类型用于给一个变量取一个别名。例如:int x=0;int/结果为:1,1在语法上,对引用类型变量的访问与非引用类型相同;但在语义上,对引用类型变量的访问实际访问的是另一个变量(被引用的变量)。,引用类型作为函数的参数类型,#i
8、nclude using namespace std;void swap(int,指针类型作为函数的参数类型,#include void swap(int*p1,int*p2)int t;t=*p1;*p1=*p2;*p2=t;void main()int a=0,b=1;cout a,b endl;/结果为:0,1swap(/结果为:1,0,void f(int*p)*p=1;p+;/OK*p=2;/危险!void g(int/b为2,a和c的值未被改变。,6.数据结构(Data Structure)定义1-是相互之间存在一种或多种特定关系的数据元素的集合。Data_Structure=(D
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 数据结构 课件 01
![提示](https://www.31ppt.com/images/bang_tan.gif)
链接地址:https://www.31ppt.com/p-5986078.html