- 1、本文档共63页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
数据结构[清华]第1章绪论
数据结构;开设本课程的背景:
《数据结构》是计算机相关专业的一门重要的专业基础课。它主要研究计算机加工对象的逻辑结构、在计算机中的存储结构以及实现各种基本操作的算法。它是学习操作系统、编译原理、数据库原理等计算机专业核心课程的基础,掌握好这门课程的内容,是学习计算机其他相关课程的必备条件。;本课程讲述的主要内容:
分别讲述数据结构的基本概念、线性表、栈和队列、串、数组和广义表、树和二叉树、图、查找、排序等内容。
学习本课程的基本方法:; 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.事前
您可能关注的文档
最近下载
- 教育、科技、人才一体化与新质生产力发展.pptx VIP
- 2024年湖南水利水电职业技术学院单招职业技能测试题库含答案(研优卷).docx VIP
- 教育、科技、人才一体化视域下发展新质生产力的四重逻辑和实践路径.docx VIP
- 教育、科技、人才一体化视域下发展新质生产力的四重逻辑和实践路径.docx VIP
- 《大棚番茄基质槽式栽培技术规程》.docx
- 立体车库 毕业论文外文翻译.docx VIP
- 教育、科技、人才一体推进新质生产力发展.docx VIP
- 2024年湖南水利水电职业技术学院单招职业技能测试题库含答案(考试直接用).docx VIP
- 社交礼仪教程(第7版 微课版)课件 第五章 餐饮礼仪.pptx
- 2025清华:DeepSeek从入门到精通.pdf
文档评论(0)