《数据结构》2.2顺序表(sequence list)
//顺序表节点的定义
typedef struct
{
datatype data[MAXSIZE]; //数组容量的上限
int len; //记录最后一个元素的位置,相当于一个指针,表空时len=-1
}SeqList;
SeqlLst L; //定义一个顺序表L,表长n = L.len+1
SeqList *L; //定义一个指向Seqlist类型的指针,L为指针变量,即顺序表的首地址 //顺序表的初始化(initialize)
SeqList *Init_SeqList()
{
SeqList *L;
L = malloc(sizeof(SeqList)); //动态分配存储空间
L->len = -;
return L;
} //插入操作(指在表的第i个位置前插入值为e的新元素,i的有效范围1<=i<=n+1,时间复杂度O(n))
int Insert_SeqList(SeqList *L, int i, datatype e)
{
int j;
if(L->len == MAXSIZE-)
{
printf("表满溢出"); return -; //表空间已满,不能插入
}
if(i< || i>L->len + ) //检查插入位置i是否有效
{
printf("位置错"); return ;
}
for(j = L->len; j > i-; j--) //在数组中,第i个元素的下标为i-1
L->data[j+] = L->data[j]; //节点往后移动一个位置
L->data[k-] = e; //插入新元素e
L->len++; //len仍指向最后一个元素
return ; //插入操作成功,返回
} //删除操作(指将中第i个位置从线性表中删除掉,i的有效范围1<=i<=n,时间复杂度O(n))
int Delete_SeqList(SeqList *L, int i)
{
int j;
if(i< || i>L->len + ) //检查空表及删除位置的合法性
{
printf("不存在第i个元素"); return ;
}
for(j = i; j <= L->len; j++)
L->data[j-] = L->data[j]; //节点向前移动一个位置
L->len--;
return ; //删除成功
} //按值查找(指在线性表中查找是否存在与给定值相等的数据元素,时间复杂度O(n))
int Locate_SeqList(SeqList *L, datatype e)
{
int i = ;
while(i<=L.len && L->data[i] != e)
i++;
if(i > L->len) return -; //查找失败
else return ; //查找成功
} //取表中元素(指根据所给序号i在线性表中查找相应数据元素,时间复杂度O(1))
int Get_SeqList(SeqList *L, int i)
{
if(i < && i > L->len+) //检查查找位置的合法性
{
printf("不存在第i个元素"); return ;
}
else return L->data[i-];
}
算法思路:
1.插入操作
(1)将an~ai顺序向后移动一个位置,即an移动到an+1的位置……ai移动到ai+1的位置,为待插入的新元素让出位置;
(2)将e放到空出的第i个位置;
(3)修改len指针,使之恒指向当前表中最后一个元素。
2.删除操作
(1)将ai+1~an顺序向前移动一个位置;
(2)修改len指针,使之仍指向当前表中最后一个元素。
3.按值查找
从第一个元素a1起依次与e比较,直到找到一个与相等的数据元素为止,返回它在顺序表中的存储下标;
若查遍整个表都没有找到与e相等的元素,则返回-1,表示查找失败。
4.取表中元素
首先确认所查找数据元素序号是否合法,若合法则直接返回对应元素值。否则报错。
《数据结构》2.2顺序表(sequence list)的更多相关文章
- C++数据结构学习之顺序表
顺序表是数据结构中最基本也是应用相当广泛的一种数据结构类型.它通常包含三个私有成分,即指向数据数组的头指针.当前表长以及表的实际容量.表的头指针通常指向数据数组的基地址,通过数组的形式进行访问数据数组 ...
- 【数据结构】之顺序表(Java语言描述)
之前总结过使用C语言描述的顺序表数据结构.在C语言类库中没有为我们提供顺序表的数据结构,因此我们需要自己手写,详细的有关顺序表的数据结构描述和C语言代码请见[我的这篇文章]. 在Java语言的JDK中 ...
- 【数据结构】之顺序表(C语言描述)
顺序表是线性表的一种,它将元素存储在一段连续的内存空间中,表中的任意元素都可以通过下标快速的获取到,因此,顺序表适合查询操作频繁的场景,而不适合增删操作频繁的场景. 下面是使用 C语言 编写的顺序表的 ...
- C++ 数据结构学习一(顺序表)
//SequentialList.h 顺序表模板类 #ifndef SEQUENTIAL_LIST_HXX#define SEQUENTIAL_LIST_HXX using std::cout; us ...
- 数据结构 单链表&顺序表
顺序表: 一般使用数组(C语言中的数组采用顺序存储方式.即连续地址存储)来描述. 优点:在于随机访问元素, 缺点:插入和和删除的时候,需要移动大量的元素. 链表: 优点:插入或删除元素时很方便,使用灵 ...
- 数据结构——Java实现顺序表
一.分析 什么是顺序表?顺序表是指用一组地址连续的存储单元依次存储各个元素,使得在逻辑结构上相邻的数据元素存储在相邻的物理存储单元中的线性表.一个标准的顺序表需要实现以下基本操作: 1.初始化顺序表 ...
- 数据结构之线性顺序表ArrayList(Java实现)
一.ListMe接口: import java.util.ArrayList; //实现线性表(顺序表和链表)的接口://提供add get isEmpty size 功能public interfa ...
- 数据结构之动态顺序表(C实现)
线性表有2种,分为顺序表和链表. 顺序表: 采用顺序存储方式,在一组地址连续的存储空间上存储数据元素的线性表(长度固定) 链表: 有3种,单链表.双向链表.循环链表(长度不固定) seqList.h ...
- 【c++版数据结构】之顺序表的实现
SeqList.h #ifndef SEQLIST_H #define SEQLIST_H #include<iostream> using namespace std; typedef ...
- 【C语言--数据结构】线性顺序表
线性表的本质: 1.线性表(List)是零个或者多个数据元素的集合: 2.线性表中的数据元素之间是有顺序的: 3.线性表中的数据元素个数是有限的: 4.线性表中的数据元素的类型必须相同: 定义: 线性 ...
随机推荐
- UIButton的文本与图片的布局
UIButton内部文本和图片的布局是我们日常代码中,不可缺少的部分,按钮默认左边图片右边文本,那要实现左边文本,右边图片,我们该怎么解决呢,上面图片,下面文本又该怎么办呢 其实很简单,今天总结下,目 ...
- Qt设计师学习笔记--Sharping-Changing Dialogs
1.pushbutton->default属性为true,按回车相当于点击该按钮. 2.选中checkable后,Button变成切换按钮(toggle button),可以有两种状态:按下/弹 ...
- linux 最小安装 需要的后续操作
在centos7 最小安装后首先需要联网 设置dns vim /etc/resolv.conf dnsxiru 写入:nameserver 8.8.8.8nameserver 8.8.4.4 网络网关 ...
- asp.net mvc bundle中数组超出索引
在使用bundle 来加载css的时候报错了, @Styles.Render("~/bundles/appStyles") 第一反应 以为是的css 太多了,可是当我这个style ...
- Java Web之会话管理一: 使用Cookie进行会话管理
一.Cookie的概念 Cookie(会话)可以简单的理解为:用户开一个浏览器,点击多个链接,访问服务器多个web资源,然后关闭浏览器,整个过程称为一个会话. 二.会话过程中解决的问题 用户在使用浏览 ...
- hadoop2.7.3配置文件中过时的属性
过时的属性:Deprecated Properties 该列表保存于:hadoop-2.7.3-src\hadoop-common-project\hadoop-common\src\site\mar ...
- Initializing connection provider: org.springframework.orm.hibernate3.LocalDataSourceConnectionProvider停住了
2015.1.24进行了服务器的搬家,搬家后,更换了新的IP,导致新的IP访问以前IP的数据库服务无法成功Initializing connection provider: org.springfra ...
- ROWID伪列
ROWID伪列概念: 在数据表中每一行所保存的记录,oracle会为每条记录分配一个唯一的地址编号,这个编号就是通过ROWID表示的. 所有的数据都利用ROWID进行定位. 观察rowid的存在 SQ ...
- 哈希表(Hash Table)
参考: Hash table - Wiki Hash table_百度百科 从头到尾彻底解析Hash表算法 谈谈 Hash Table 我们身边的哈希,最常见的就是perl和python里面的字典了, ...
- Maven 手动添加 JAR 包到本地仓库
Maven 确确实实是个好东西,用来管理项目显得很方便,但是如果是通过 Maven 来远程下载 JAR 包的话,我宿舍的带宽是4兆的,4个人共用,有时候用 Maven 来远程下载 JAR 包会显得很慢 ...