数据结构 绪论 什么是数据结构课件.ppt

  1. 1、本文档共63页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
数据结构 绪论 什么是数据结构课件

数据结构;开设本课程的背景: 《数据结构》是计算机相关专业的一门重要的专业基础课。它主要研究计算机加工对象的逻辑结构、在计算机中的存储结构以及实现各种基本操作的算法。它是学习操作系统、编译原理、数据库原理等计算机专业核心课程的基础,掌握好这门课程的内容,是学习计算机其他相关课程的必备条件。;本课程讲述的主要内容: 分别讲述数据结构的基本概念、线性表、栈和队列、串、数组和广义表、树和二叉树、图、查找、排序等内容。 学习本课程的基本方法:; 1.1 什么是数据结构;学习提要: 1. 熟悉各名词术语的含义,掌握基本概念。 2.了解抽象数据类型的定义、表示和实现方法。 3. 理解算法五个要素的确切含义,掌握估算算法时间复杂度的方法。 重难点内容: 数据的逻辑结构、数据存储结构、时间复杂度的估算方法 ;§1.1 什么是数???结构;数值计算的程序设计问题: 例如: 结构静力分析计算 ─━ 线性代数方程组 预报人口增长情况 ─━ 微分方程;非数值计算的程序设计问题:;例2 书目自动检索系统;例3 人机对奕问题;例4 教学计划编排问题 ;概括地说:;§1.2 基本概念和术语;数据(data):所有能被输入到计算机中,且被计算机处理的符号的集合 ,是计算机操作的对象的总称。 数据元素(data element):是数据(集合)中的一个“个体”,是数据的基本单位,由若干个数据项组成,也称结点、元素、顶点或记录。; 数据项:;数据结构(data structure): 是指互相之间存在着一种或多种关系的数据元素的集合。 或者说,数据结构是带结构的数据元素的集合。;例:一个含12位数的十进制数可以用三个4位的十进制数表示 3214, 6587, 9345 a1(3214), a2(6587), a3(9345) 在a1、a2、a3 之间存在“次序”关系: ?a1,a2?、?a2,a3?;又例,在2行3列的二维数组{a1, a2, a3, a4, a5, a6};再例,在一维数组 {a1, a2, a3, a4, a5, a6} 的数据元素之间存在如下的次序关系:;集合结构:数据元素间 “同属于一个集合”;数据结构的形式定义为:;;数据的逻辑结构:只抽象反映数据元素的逻辑关系。;数据元素的映象方法:;关系的映象方法:;2、链式映象;例如:复数z1=3.0-2.3i,z2=-0.7+4.8i的存储结构。;二、数据类型;例:C语言中,提供 int, char, float等基本数据类型, 数组、结构体、共用体、枚举等构造数据类型 指针、空(void)类型等。 用户也可用typedef 自己定义数据类型; 数据类型 是一个 值的集合 和定义在此集合上的 一组操作 的总称。;三、抽象数据类型 (Abstract Data Type 简称ADT); 例如: 矩阵 +(求转置、加、乘、求逆、求特征值) 构成一个矩阵的抽象数据类型。 ;ADT的描述方法:;ADT 抽象数据类型名 { 数据对象:〈数据对象的定义〉 数据关系:〈数据关系的定义〉 基本操作:〈基本操作的定义〉 } ADT 抽象数据类型名;赋值参数:只为操作提供输入值。 引用参数:以打头,除可提供输入值外, 还将返回操作结果。;例如,抽象数据类型复数的定义:;基本操作:; GetImag( Z, ImagPart ) 初始条件:复数已存在。 操作结果:用ImagPart返回复数Z的虚部值。;假设:z1和z2是上述定义的复数;ADT 有两个重要特征:;ADT的表示和实现:;typedef struct { float realpart; float imagpart; }complex;;float GetReal( complex Z ); // 返回复数 Z 的实部值;// -----基本操作的实现;一、算法的定义; 算法是对特定问题求解步骤的描述,是指令的有限序列。;1.有穷性:对于任意一组合法输入值,在执行有穷步骤之后一定能结束,即算法中的每个步骤都能在有限时间内完成。;3.可行性:算法中的所有操作都必须足够基本,都可以通过已经实现的基本操作运算有限次实现之。;二、算法设计的原则;1.正确性:在合理的数据输入下,能在有限的运算时间内得到正确结果。;2.可读性:易于人对算法的理解;另一方面,晦涩难读的程序易于隐藏较多错误而难以调试;;4.高效率与低存储量需求:;有两种衡量算法效率的方法: 1.事后统计法:利用计算机内记时功能,用一组或多组相同的统计数据区分。 2.事前

文档评论(0)

gm8099 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档