C 线性表的顺序存储实现及插入、删除等操作示例
一、线性表的定义
线性表(Linear List)是由同一类型元素构成的有序序列的线性结构。线性表中元素的个数称为线性表的长度;线性表内没有元素(长度为0)时,称为空表;表的起始位置称为表头,表的结束位置称为表尾。
线性表的抽象数据类型描述为:
类型名称:线性表(List)
数据对象集:线性表是由n个元素构成的有序序列(a1到an),其中a1是表的第一个元素(表头),an是表的最后一个元素(表尾)。ai+1称为ai的直接后继,ai称为ai+1的直接前驱,直接后继和直接前驱反映了元素之间一对一的邻接逻辑关系。
操作集:对于一个具体的线性表L,其内部有表示位序的整数i以及和其对应的元素x。
二、线性表的顺序存储实现
线性表的顺序存储是指在内存中用地址连续的一块存储空间顺序存放线性表的各元素。在程序设计语言中,一维数组在内存中占用的存储空间就是一组连续的存储区域,因此,用一维数组来表示顺序存储的数据区域是再适合不过了。
考虑到线性表的操作有插入、删除等,及表的长度是动态可变的,因此,数组的容量需设计得足够大。假设用Data[MAXSIZE]表示,其中MAXSIZE是一个根据实际问题定义的足够大的整数,线性表中的数据从Data[0]开始顺序存放。由于当前线性表中的实际元素可能未达到MAXSIZE多个,因此需要用一个变量Last来记录当前线性表中最后一个元素在数组中的位置。即Last起一个指针(实际是数组下标)的作用,始终指向线性表的最后一个元素。表空时Last = -1。
如下图所示,若当前表长为Last +1,数据元素a0,a1......an分别存储在Data[0]到Data[Last]之间。
typedef struct LNode* List;
struct LNode
{
int Data[20];
int lastPosition;//最后一个元素下标值
};
三、线性表的基本操作
3.1 List MakeEmpty():初始化一个新的空线性表
//创建线性表并初始化为空
List MakeEmpty()
{
List L;
L = (List)malloc(sizeof(struct LNode));//申请内存空间
L->lastPosition = -1;//lastPosition置为-1,说明表空
return L;
}
3.2 int FindKth(List L, int P):根据制定的位序P,返回L中相应的元素
//返回指定位置的元素值
int FindKth(List L, int P)
{
if (P > L->lastPosition)
return -1;
else
return L->Data[P];
}
3.3 int Find(List L, int X):返回L中第一个X元素的下标值
//寻找线性表中第一个X的下标
int Find(List L, int X)
{
for (int i = 0; i <= L->lastPosition+1; i++)
{
if (i == L->lastPosition+1)
return -1;//未找到
else if (L->Data[i] == X)
return i;//返回对应下标
}
}
3.4 bool Insert(List L, int P, int X):在L中下标为P的位置插入X
插入元素时,先将线性表长度向后扩展1个元素长,之后将要插入位置及其后面的所有元素均向后移动一位,空出位置后再将新元素插入。
//在下标为P的位置插入X
bool Insert(List L, int P, int X)
{
if (L->lastPosition == 20 || P > L->lastPosition)//如果线性表已满或所插位置不在线性表内,返回false
return false;
L->lastPosition++;//若能插入,线性表长度加1
//从P位置到最后,所有元素均向后移一位
for (int i = L->lastPosition; i > P; i--)
{
L->Data[i] = L->Data[i-1];
}
L->Data[P] = X;//在空出的P位置插入新的元素
return true;
}
3.5 bool Delete(List L, int P):删除L中下标为P的元素
将相应位置元素删除后,原来在其后面的元素均向前移动一位,空出最后一个位置,最后将线性表长度减去1个元素长,删去线性表空余的位置。
//删除下标为P的元素
bool Delete(List L, int P)
{
if (P > L->lastPosition)//如果所删元素位置不在线性表内,返回false
return false;
//将位置P后的元素均向前移一位
for (int i = P; i < L->lastPosition; i++)
{
L->Data[i] = L->Data[i + 1];
}
L->lastPosition--;//成功删除原位置为P的元素,线性表长度减1
return true;
}
3.6 int Length(List L):返回线性表L长度
//返回线性表L长度
int Length(List L)
{
return L->lastPosition + 1;
}
C 线性表的顺序存储实现及插入、删除等操作示例的更多相关文章
- 2.2_线性表的顺序存储结构_参考集合ArrayList
[线性表的顺序存储从结构] 指的是用一段连续的存储单元一次储存线性表的数据元素. [线性表的顺序存储的结构代码 C语言版] #define MAXSIZE 20 /*存储空间初始分配量*/ typed ...
- 线性表的顺序存储结构——java
线性表的顺序存储结构:是指用一组地址连续的存储单元一次存放线性表的元素.为了使用顺序结构实现线性表,程序通常会采用数组来保存线性中的元素,是一种随机存储的数据结构,适合随机访问.java中ArrayL ...
- C++编程练习(1)----“实现简单的线性表的顺序存储结构“
线性表的顺序存储结构,指的是用一段地址连续的存储单元依次存储线性表的数据元素. 故可以用数组来实现顺序存储结构. 用C++编写的利用数组实现简单的读取.插入和删除功能的线性表. #include< ...
- 算法与数据结构(一) 线性表的顺序存储与链式存储(Swift版)
温故而知新,在接下来的几篇博客中,将会系统的对数据结构的相关内容进行回顾并总结.数据结构乃编程的基础呢,还是要不时拿出来翻一翻回顾一下.当然数据结构相关博客中我们以Swift语言来实现.因为Swift ...
- C 线性表的链式存储实现及插入、删除等操作示例
一.链式存储的优势 线性表的存储可以通过顺序存储或链式存储实现,其中顺序存储基于数组实现(见本人上一篇博客),在进行插入删除等操作时,需对表内某一部分元素逐个移动,效率较低.而链式结构不依赖于地址连续 ...
- 【Java】 大话数据结构(1) 线性表之顺序存储结构
本文根据<大话数据结构>一书,实现了Java版的顺序存储结构. 顺序存储结构指的是用一段地址连续的存储单元一次存储线性表的数据元素,一般用一维数组来实现. 书中的线性表抽象数据类型定义如 ...
- 线性表的顺序存储结构之顺序表类的实现_Java
在上一篇博文——线性表接口的实现_Java中,我们实现了线性表的接口,今天让我们来实现线性表的顺序存储结构——顺序表类. 首先让我们来看下顺序表的定义: 线性表的顺序存储是用一组连续的内存单元依次存放 ...
- 数据结构4:顺序表(线性表的顺序存储结构)及C语言实现
逻辑结构上呈线性分布的数据元素在实际的物理存储结构中也同样相互之间紧挨着,这种存储结构称为线性表的顺序存储结构. 也就是说,逻辑上具有线性关系的数据按照前后的次序全部存储在一整块连续的内存空间中,之间 ...
- 线性表的顺序存储和链式存储的实现(C)
//线性表的顺序存储 #include <stdio.h>typedef int DataType;#define MaxSize 15//定义顺序表typedef struct { Da ...
随机推荐
- CentOS7 安装VNC
系统环境:CentOS Linux release 7.6.1810Kernel:3.10.0-957.el7.x86_64系统现状:最小化安装,没有安装任何图形支持软件 安装图形化支持 不建议安装G ...
- MySQL索引优化步骤总结
在项目使用mysql过程中,随着系统的运行,发现一些慢查询,在这里总结一下mysql索引优化步骤 1.开发过程优化 开发过程中对业务表中查询sql分析sql执行计划(尤其是业务流水表),主要是查看sq ...
- 响应式web设计(一)
很多网页都是基于网格设计的,这说明网页是按列来布局的. 原理就是讲网页分成十二列,每列的宽度是8.33%,元素的宽度,用几列来定义,正是因为这一点,才可以做到响应,就是随着窗口宽度的变化,给元素分配不 ...
- File初识和练习
目录 File类 File对象的构建 File文件名.路径的获取 文件的状态 文件的其他操作 创建文件夹 列出下一级 实战练习1:列出子孙级目录及名称 实战练习2:列出文件及其子孙文件的总大小 实战练 ...
- 【aardio】]SQL创建、读写 excel
import access; var db,err = access( "/test.xls" ) //文件不存在可自动创建 //创建表 if( ! db.existsTable( ...
- linux学习第十九天 (Linux就该这么学) 结课了
今天最后一天课程了,结课了,还有点舍不得那,在些也祝 李老师 事业蒸蒸日上,超来超好, 今天内容是部署了 LNMP 部署动态网站环境(linux +nginx+mysql+php) 安装文件挺别多, ...
- Python 3.6版本中实现 HTMLTestRunner输出时”fp=file(filename,'wb')“报错
原错误代码: if __name__=='__main__': suite=unittest.makeSuite(WidgetTestCase) filename='D:\\myreport.html ...
- Java中如何创建一个新的对象的/Creating Objects/
The Java Tutorials have been written for JDK 8. Examples and practices described in this page don't ...
- Web3D
https://baike.baidu.com/item/WEB%203D/11066359?fr=aladdin https://zhidao.baidu.com/question/17325151 ...
- 使用kbmmw 的REST 服务实现上传大文件
我们在使用kbmmw的REST 服务时,经常会下载和上传大文件.例如100M以上的.kbmmw的rest服务中 提供标准的文件下载,上传功能,基本上就是打开文件,发送,接收,没有做特殊处理.这些对于文 ...