//顺序表节点的定义
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. JAVA程序操作hbase的Maven配置pom.xml文件

    由于工作需要,用到Java连接Hbase读写数据.原来的方式是直接将依赖的jar包全部下载下来,然后工程里面引用. 现想重构下,改为使用Maven管理,遇到了各种坑,各种不好使,特总结下. <d ...

  2. ProcessExplore 最新版

    http://files.cnblogs.com/files/zhangdongsheng/ProcessExplorer.zip

  3. Windows安装Scrapy遇坑解决办

    PS: Windows真心不适合开发.且行且珍惜.... 坑: error: Setup script exited with error: Microsoft Visual C++ 9.0 is r ...

  4. dsp28377控制DM9000收发数据

    首先感谢上一篇转载文章的作者给出的参考,下面是一些自己在调试过程中的一些步骤: 首先把代码贴上来: //------------------------------------------------ ...

  5. Codeforces 722C. Destroying Array

    C. Destroying Array time limit per test 1 second memory limit per test 256 megabytes input standard ...

  6. Django + mysql 快速搭建简单web投票系统

    了解学习pyhton web的简单demo 1. 安装Django, 安装pyhton 自行百度 2. 执行命令创建project  django-admin.py startproject mysi ...

  7. Javascript 字符串常用操作方法

    1.字符串转换 /* 你可以将一个数字,布尔值,或一个字符串对象转换为字符串 */ var num= 18; var str1 = num.toString(); //'18' var str2 = ...

  8. FFmpeg官方文档之————先进音频编码(AAC)

    先进音频编码(AAC)的后继格式到MP3,和以MPEG-4部分3(ISO / IEC 14496-3)被定义.它通常用于MP4容器格式; 对于音乐,通常使用.m4a扩展名.第二最常见的用途是在MKV( ...

  9. 非标准JSON解析

    http://blog.csdn.net/superit401/article/details/51734591 String category = "{'v-soft-list':[{ty ...

  10. 首页自动生成静态化html

    由于平台老是出现间歇性502.排查发现,php死进程过多耗费大量系统资源. 除了优化代码之外,静态化可以减少php进程.缓解一下服务器压力. 把首页生成html后,出现问题频率下降.所以需要做首页静态 ...