数据结构和算法-学习笔记3

线性表(List)

定义:由零个或多个数据元素组成的有限序列。

关键词

①序列:它是一个序列,元素之间是有先后顺序的

②若元素存在多个:第一个元素无前驱,而后一个元素无后继,其它元素只有一个前驱和后继

③有限的

数学语言定义如下

若将线性表记为(a1,...,ai-1,ai,ai+1,...,an),则表中ai-1领先于ai,ai领先于ai+1,称ai-1是ai的直接前驱元素,ai+1是ai的直接后继元素

线性变元素的个数N(n>=0)定义为线性表的长度,当n=0是,称为空表

抽象数据类型

数据类型的定义:是指一组性质相同的值得集合及定义在此集合上的一些操作的总称(如整型,浮点型等)

C语言中数据类型可以分为两类

原子类型:不可以再分解的基本类型,如整型、浮点型、字符型等。

结构类型:由若干个类型组合而成,是可以再分解的,如整型数组

抽象:是指抽取出事务具有的普遍性的本质。它要求抽出问题的特征而忽略非本质的细节,是对事物的一个概括。抽象是一种思考问题的方式,它隐藏了繁杂的细节。

我们对已有数据类型进行抽象,就有了抽象数据类型

抽象数据类型(ADT)是指一个数学模型及定义在该模型上一组操作

意义:在于数据类型的数学抽象特性

抽象数据类型的标准格式(伪代码):

ADT  抽象数据类型

Data

数据元素之间逻辑关系的定义

Operation

操作

endADT

线性表的抽象数据类型定义:

ADT线性表(List)

Data:

线性表的数据对象集合为{a1,a2,...,an},每个元素的类型均为DataType。其中,除第一个a1外,以外的每一个元素有且只有一个直接前驱元素,除了最后一个元素an外,每一个元素有且只有一个后继元素,数据元素之间是一对一的关系

Operation:以下几种操作

InitList(*L):初始化操作,建立一个空的线性表L

ListEmpty(L):判断线性表是否为空表,若线性表为空,返回true,否则返回false

ClearList(*L):将线性表清空

GetElem(L,i,*e):将线性表L中的第i个位置元素值返回给e

LocateElem(L,e):在线性表L中查找与给定值e相等的元素,如果查找成功,返回改元素在表中序号表示成功;否则,返回0表示失败。

ListInsert(*L,i,e):在线性表L中第i个位置插入新元素e

ListDelete(*L,i,e):删除线性表L中第i个位置元素,并用e返回其值

ListLength(L):返回线性表L的元素个数

endADT

例如:实现A=A∪B

我们需要用的基本操作组合

ListLength(L)--返回元素个数

GetElem(L,i,*e)--将线性表L中的第i个位置元素值返回给e

LocataElem(L,e)--在线性表L中查找与给定值e相等的元素,如果查找成功,返回改元素在表中序号表示成功;否则,返回0表示失败。

ListInsert(*L,i,e)--在线性表L中第i个位置插入新元素e

实例代码:

线性表两种存储结构

顺序存储:指用一段地址连续的存储单元依次存储线性表的数据元素(如数组)

顺序存储结构代码:

#define MAXSIZE 20

typedef int ElemType;

typedef struct

{

ElemType data[MAXSIZE];

int length;

}SqList;

结构封装需要三个属性:

存储空间的起始位置,数组data,它的存储位置就是线性表存储空间的存储位置

线性表的最大存储容量:数组长度MAXSIZE

线性表的当前长度:length

地址计算方法:

假设ElemType占用的是C个存储单元,你们线性表中第i+1个数据元素和第i个数据元素的关系是

LOC(ai+1)=LOC(ai)+c

代码段:

链式存储:

时间: 2024-10-17 07:23:08

数据结构和算法-学习笔记3的相关文章

数据结构与算法学习笔记(一)

我们把数据结构分为逻辑结构和物理结构 逻辑结构:是指数据对象中数据元素之间的相互关系. 物理结构:是指数据的逻辑结构在计算机中的存储形式. 四大逻辑结构: 集合结构:集合结构中的数据元素除了同属于一个集合外没有其他的相互关系. 线性结构:线性结构中的数据元素之间是一对一的关系. 树形结构:树形结构中的元素之间存在一种一对多的层次关系. 图形结构:图形结构的元素之间是多对多的关系. 物理结构:物理结构主要研究如何把数据元素存储到计算机的存储器中. 数据元素的存储形式: 顺序存储:把数据元素存放在地

数据结构和算法-学习笔记1

什么是数据结构? 数据结构是一门研究非数值计算的程序设计问题中的操作对象,以及它们之间的关系和操作等相关问题的学科. 程序设计=数据结构+算法(简单说就是关系,数据元素相互之间存在的一种或多种特定关系的集合) 数据结构分为逻辑结构和物理结构 逻辑结构(集合结构.线性结构.树形结构.图形结构) 数据对象中的数据元素之间的相互关系 集合机构 集合结构中的元素除了同属于一个集合外,他们之间没有其它关系 线性结构 线性结构中的数据元素之间是一对一的关系 树形结构 树形结构中的数据元素之间存在一种一对多的

数据结构 试探法算法学习笔记

彩票1-29  输出7个不相同的数 #include<stdio.h> int main() { int i[7],j; for(i[0]=1;i[0]<=29;i[0]++) for(i[1]=1;i[1]<=29;i[1]++) { if(i[0]==i[1]) continue; for(i[2]=1;i[2]<=29;i[2]++) { if(i[0]==i[2]||i[1]==i[2]) continue; for(i[3]=1;i[3]<=29;i[3]++

数据结构与算法学习笔记(四)

单链表的整表创建 声明一结点p和计数器变量i 初始化一空链表L 让L的头结点的指针指向NULL,即建立一个带头结点的单链表 循环实现后继结点的赋值和插入 头插法:从一个空表开始,生成新节点,读取数据存放到新结点的数据域中,然后将新结点插入到当前链表的表头上,直到结束位置.简单来说就是把新加进的元素放在表头后的第一个位置 先让新结点的next指向头结点之后 然后让表头的next指向新结点 void CreateListHead (LinkList *L,int n) { LinkList p; i

数据结构和算法-学习笔记7

静态链表 静态链表:用数组描述的链表,描述方式叫做游标实现法 线性表的静态链表存储结构 #define MAXSIZE 1000 typedef struct { Elemtype data;//数据 int cur;//游标 }Component,StaticLinkList[MAXSIZE]; 注最后一个元素的游标应该是0 静态链表初始化 Status InitList(StaticLinkList space) { int i; for(i =0;i<MAXSIZE-1;i++) spac

数据结构与算法-学习笔记6

单链表的整表创建.删除 单链表的整表创建 思路: -声明一个结点p和计数器变量i -初始化一个空链表L -让L的头结点的指针指向NULL,即建立一个带头结点的单链表: -循环实现赋值和插入 头插法建表 从一个空表开始,生成新结点,读取数据存放到新节点的数据域中,然后将新节点插入到当前链表的表头上,直到结束为止. 如,我们将hello插入链表中 代码: void CreateListHead(LinkList *L,int e) { LinkList p; int i; srand(time(0)

数据结构和算法-学习笔记5

线性表两种存储结构-链式存储 定义:用一组任意的存储单元存储线性表的数据元素,这组存储单元可以存在内存中未被占用的任意位置 我们把存储数据元素信息的域称为数据域,把存储直接后继位置的域称为指针域.指针域中存储的信息称为指针或链.这两部分信息组成数据元素称为存储映像,称为结点(Node) 单链表 头结点和头指针的区别 头指针: -链表指向第一个结点的指针,若链表有头结点,则是指向头结点的指针 -头指针具有标示作用,所以常用头指针冠以链表的名字 -无论链表是否为空,头指针均不为空 -头指针是链表的必

数据结构和算法-学习笔记4

线性表两种存储结构-顺序存储 顺序存储结构代码: #define MAXSIZE 20 typedef int ElemType; typedef struct { ElemType data[MAXSIZE]; int length; }SqList; 结构封装需要三个属性: 存储空间的起始位置,数组data,它的存储位置就是线性表存储空间的存储位置 线性表的最大存储容量:数组长度MAXSIZE 线性表的当前长度:length 地址计算方法: 假设ElemType占用的是C个存储单元,你们线性

KMP算法 学习笔记

kmp算法在很多人看来是如此的厉害,很早之前就学过了,但是各种看不懂把我拦住了,现在重新拾取,来写一下个人的学习总结. kmp看毛片算法(小甲鱼教的)(在这给小甲鱼做个广告,我个人看来小甲鱼讲的数据结构很好,很有趣.个人创业不容易,希望大家多多支持www.fishc.com小甲鱼,我跟小甲鱼素不相识,只是有用的东西大家分享) 好了言归正传. 如果你之前看过kmp算法没有看懂希望在这不要带着一种恐惧感,如果你没看过那是更好. 网上有很多详细教程,但是大部分都很啰嗦,容易把人看晕. kmp算法没有什