- 1、本文档共26页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第二章线性表(顺序表)
2222 第2章 线性表 2.1 线性表的类型定义 2.2 线性表的顺序表示和实现 2.3 线性表的链式表示和实现 2.4 一元多项式的表示及相加 * * 2.1 线性表的类型定义 线性表的概念 线性表的逻辑结构是具有相同类型的n个数据元素的有限序列: L=(D,R) 其中R为D上的一个二元关系 D ={ a1 ,a2 ,…,an } R ={ ai,ai+1 | 1≤i≤n-1 ,ai∈D} 有序对 ai(i=1,...,n)是属于某数据对象的元素, n为线性表的长度(n≥0),n=0的表称为空表。 例 英文字母表(A,B,C,…..Z)是一个线性表 例 学生信息表 也是线性表 线性表的结构特点 (1)所有数据元素ai在同一个线性表中必须是相同的数据类型; (2)在非空线性表中必存在唯一的一个称为“头”的元素; (3)在非空线性表中必存在唯一的一个称为“尾”的元素; (4)除“头”外,每个元素都有且只有一个前驱元素。 (5)除“尾”外,每个元素都有且只有一个后继元素。 2.1 线性表的类型定义 顺序存储结构(顺序表) 用一组地址连续的存储单元依次存放线性表的数据元素,称为线性表的顺序存储结构。 地址计算:设每个元素占L个单元,并以所占的第一个单元的存储地址作为数据元素的存储位置。则线性表中第i+1个数据元素的存储位置LOC(ai+1)= LOC(ai)+L 线性表的第i个数据元素ai 的存储位置为 LOC(ai)= LOC(a1)+(i-1)*L LOC(a1)通常称作线性表的起始位置或基地址。 2.2 线性表的顺序表示和实现 ? 特点: (1)逻辑上相邻的数据元素在物理上也相邻; (2)是顺序存储结构、随机存取数据元素。 这种存储结构只要知道元素的序号,就很容易找到第i个数据元素,且无论序号i为何值,找到第i个元素所需时间相同。 2.2 线性表的顺序表示和实现 表示方式: 数组表示:注意:C语言中,数组下标从0开始。 #define MAX 100 //常量定义 datatype data[MAX]; int length; datatype为抽象数据类型,可用int, float, double, char 或结构体类型代替。如: typedef int datatype length为顺序表当前长度 2.2 线性表的顺序表示和实现 a1 a2 an 0 1 n-1 1 2 n 内存 数组下标 元素序号 Max-1 #define Max 100 int data[Max]; int n; 例 typedef struct student { int num; char name[20]; int age ; float score; }datatype; #define Max 100 datatype class1[Max]; int n; 备用空间 数据元素不是简单类型时,可定义结构体数组 ? 表示方式: 将length与data封装在一起,单独定义一种顺序表类型—用结构体建立。 例 #define MAX 1000 typedef struct { int data[MAX]; int length; }SeqList; 如何声明变量(顺序表)L? SeqList L; L. length =2; L.data[0]=91; L.data[1]=82; SeqList即为顺序表类型,可用该类型建立很多顺序表。 思考:如何定义学生的顺序表? 2.2 线性表的顺序表示和实现 #define MAX 1000 typedef struct student { int num; char name[20]; int age ; float score; }stu; typedef struct List { stu data[MAX]; int length; }SeqList; 如何定义学生的顺序表? #define MAX 1000 struct student { int num; char
您可能关注的文档
- 第三章软件缺与陷测试定义.ppt
- 第三组物流基–础实践报告.ppt
- 第三讲–AVR开发基础知识.ppt
- 第三章语音和音系第六节音位的组合.ppt
- 第三节人类的起源与进化(第二课时).ppt
- 第三讲基本初等函数.ppt
- 第三讲游戏中的关卡.ppt
- 第三讲电脑正确的开关机操作.ppt
- 第三课–单片机汇编语言–IO口.ppt
- 第三章程序设计初(I).ppt
- 湖南省湘西土家族苗族自治州行政职业能力测验模拟试题及答案1套.docx
- 浙江省杭州市行政职业能力测验题库带答案.docx
- 湖北省襄樊市行政职业能力测验题库含答案.docx
- 浙江省温州市选调生考试(行政职业能力测验)综合能力测试题含答案.docx
- 河南省焦作市行政职业能力测验题库及答案1套.docx
- 湖北省黄冈市行政职业能力测验模拟试题新版.docx
- 河南省焦作市行政职业能力测验模拟试题必考题.docx
- 河北省邢台市行政职业能力测验题库及参考答案1套.docx
- 2025年柳州城市职业学院单招(语文)测试模拟题库完美版.docx
- 河南省南阳市选调生考试(行政职业能力测验)综合能力题库学生专用.docx
文档评论(0)