- 1、本文档共86页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
对数据结构内容的把握首要解决的是对数据组织形式的两种存储结构的理解问题 :
顺序结构和链式结构
基本数据结构包括:
线性表、栈、队列、树和图
涉及到物理的存储结构和数组、结构体和指针三种数据类型等相关知识。 ;各章学习的要求(2);第二章 线性表和串;内容:;2.1 线性表的定义;(a1, a2, … ai-1,ai, ai+1 ,…, an)
;;“同一数据逻辑结构中的所有数据元素都具有相同的特性”是指数据元素所包含的数据项的个数都相等。;2.1.2 线性表的抽象数据类型 ;OPSet:
Creat() 构造空线性表
Output () 将线性表中的数据元素进行输出
GetElem(k, x)简介在线性表中取第k个元素到x中
Search(x) 在线性表中查找元素x
Insert(k, x) 在线性表中第k个数据元素之后中插入元素x
Delete(k ) 在线性表中删除第k个数据元素
PreElem(k, x) 在线性表中求第k个元素的前驱,存入x中
PreElem (k, x) 在线性表中求第k个元素的后继,存入x中
IsEmpty() 判断线性表中有无元素
}
;2.2 线性表的顺序存储及操作 ;2.2.1 线性表顺序存储;*element→;*element→;设每个元素占用存储空间(地址长度)为Size字节,线性表的第一个元素的物理地址(称为基地址),则表中任一数据元素的存放地址为:;2.线性表顺序存储结构定义与实现 ;学生信息线性表 ;2.2.2 线性表顺序存储结构下的操作 ;#define MaxListSize 100;
Typedef xxx EType;
void Creat(LinearList &L , int &MaxListSize)
{// 构造一个最大容量为MaxListSize 的线性表L
L.MaxSize = MaxListSize;
L.element = new EType [L.MaxSize];
//L. element=new Student[5];
L.length = 0;
}。;2. 将线性表L中的数据元素进行输出;3.线性表L中取第k个元素 ;4.线性表L中查找元素x;地址传递
void swap(int *x, int *y )
{
int temp;
temp = *x;
*x =*y;
*y = temp ;
}
;值传递
void swap(int x, int y )
{
int temp;
temp = x;
x =y;
y = temp ;
}
;查找元素x ;int Search(LinearList &L, const EType &x)
{
// 查找x,如果找到,返回x所在的位置下标;如果未找到返回-1
for (int i = 0; i < L.length; i++)
if (L.element[i] == x)
return i;
return -1;
} ;5.线性表L中第k个数据元素之后插入元素x运算 ; (a1, …, ai-1, ai, …, an) 改变为;21 18 30 75 42 56 87;算法的时间复杂性是O(length-k);6.线性表L中删除第k个数据元素运算 ; (a1, …, ai-1, ai, ai+1, …, an) 改变为;21 18 30 75 42 56 87 63;删除运算是指需要删除线性表中的第K个数据元素,即删除ek-1 ;例1:设有一维数组M,下标的范围是0到9,每个数组元素用相邻的5个字节存储。存储器按字节编址,设存储数组元素M[0]的第一个字节的地址是98,则M[3]的第一个字节的地址是多少?;核心语句:
法1 V[i]= V[i-1]+1;
法2 V[i]=’a’+i;
法3 V[i]=97+i;;顺序存储结构小结; 程序设计:
Creat(…) 构造空线性表
Output (…) 将线性表中的数据元素进行输出
Search(…) 在线性表中查找元素x
Insert(…) 在线性表中第k个数据元素之后中插入元素x
Delete(…) 在线性表中删除第k个数据元素
要求:1)建立包含5个student的顺序表,2)在3后插入一个student ,3)删除4,4)打印顺序表
写出程序的框架代码.包括:头文件,表结构定义
,常量定义,设计上述函数的调用顺序及其参数。;;其结点在存储器中的位置是随意的,即逻辑上相邻的数据元素在物理上不一定相邻。;简单链表的存储结构定义 ;typedef struct ChainN
文档评论(0)