//顺序表节点的定义
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)的更多相关文章

  1. C++数据结构学习之顺序表

    顺序表是数据结构中最基本也是应用相当广泛的一种数据结构类型.它通常包含三个私有成分,即指向数据数组的头指针.当前表长以及表的实际容量.表的头指针通常指向数据数组的基地址,通过数组的形式进行访问数据数组 ...

  2. 【数据结构】之顺序表(Java语言描述)

    之前总结过使用C语言描述的顺序表数据结构.在C语言类库中没有为我们提供顺序表的数据结构,因此我们需要自己手写,详细的有关顺序表的数据结构描述和C语言代码请见[我的这篇文章]. 在Java语言的JDK中 ...

  3. 【数据结构】之顺序表(C语言描述)

    顺序表是线性表的一种,它将元素存储在一段连续的内存空间中,表中的任意元素都可以通过下标快速的获取到,因此,顺序表适合查询操作频繁的场景,而不适合增删操作频繁的场景. 下面是使用 C语言 编写的顺序表的 ...

  4. C++ 数据结构学习一(顺序表)

    //SequentialList.h 顺序表模板类 #ifndef SEQUENTIAL_LIST_HXX#define SEQUENTIAL_LIST_HXX using std::cout; us ...

  5. 数据结构 单链表&顺序表

    顺序表: 一般使用数组(C语言中的数组采用顺序存储方式.即连续地址存储)来描述. 优点:在于随机访问元素, 缺点:插入和和删除的时候,需要移动大量的元素. 链表: 优点:插入或删除元素时很方便,使用灵 ...

  6. 数据结构——Java实现顺序表

    一.分析 什么是顺序表?顺序表是指用一组地址连续的存储单元依次存储各个元素,使得在逻辑结构上相邻的数据元素存储在相邻的物理存储单元中的线性表.一个标准的顺序表需要实现以下基本操作: 1.初始化顺序表 ...

  7. 数据结构之线性顺序表ArrayList(Java实现)

    一.ListMe接口: import java.util.ArrayList; //实现线性表(顺序表和链表)的接口://提供add get isEmpty size 功能public interfa ...

  8. 数据结构之动态顺序表(C实现)

    线性表有2种,分为顺序表和链表. 顺序表: 采用顺序存储方式,在一组地址连续的存储空间上存储数据元素的线性表(长度固定) 链表: 有3种,单链表.双向链表.循环链表(长度不固定) seqList.h ...

  9. 【c++版数据结构】之顺序表的实现

    SeqList.h #ifndef SEQLIST_H #define SEQLIST_H #include<iostream> using namespace std; typedef ...

  10. 【C语言--数据结构】线性顺序表

    线性表的本质: 1.线性表(List)是零个或者多个数据元素的集合: 2.线性表中的数据元素之间是有顺序的: 3.线性表中的数据元素个数是有限的: 4.线性表中的数据元素的类型必须相同: 定义: 线性 ...

随机推荐

  1. jshzoi

    解题报告——2018级2016第二学期第一周作业   解题报告——2018级2016第二学期第一周作业 D 算24 题目描述 描述 给出4个小于10个正整数,你可以使用加减乘除4种运算以及括号把这4个 ...

  2. github项目配置

    准备工作: 下载一个git:  https://git-scm.com/downloads 1.登陆到github 登陆地址:https://github.com/login 2.创建新项目 3.配置 ...

  3. django_cms安装技巧

    首先python的版本要高一些,否则安装django-cms会报错 安装cmsinstaller不能够正常下载 利用virtualenv进行安装配置 注意中文的配置 djangocms配置中文 dja ...

  4. rxjava源码中的线程知识

    rxjava源码中的线程知识 rx的最精简的总结就是:异步 这里说一下以下的五个类 1.Future2.ConcurrentLinkedQueue3.volatile关键字4.AtomicRefere ...

  5. Android中Context详解

    大家好,  今天给大家介绍下我们在应用开发中最熟悉而陌生的朋友-----Context类 ,说它熟悉,是应为我们在开发中时刻的在与它打交道,例如:Service.BroadcastReceiver.A ...

  6. JQuery_元素属性操作

    除了对元素内容进行设置和获取,通过jQuery 也可以对元素本身的属性进行操作,包括获取属性的属性值.设置属性的属性值,并且可以删除掉属性. <script type="text/ja ...

  7. 绿色 或者 免安装 软件 PortableApps

    Refer to http://portableapps.com/apps for detail. Below is just a list at Jan-01-2017 for quick show ...

  8. string 常量池的理解

    1: String a="123"; String b="12"+"3"; String c="1"+"23& ...

  9. 0.读书笔记之The major advancements in Deep Learning in 2016

    The major advancements in Deep Learning in 2016 地址:https://tryolabs.com/blog/2016/12/06/major-advanc ...

  10. python虚拟环境

    sudo apt-get install python-virtualenv virtualenv --no-site-packages files cd files source ./bin/act ...