线性表,即线性存储结构,将具有“一对一”关系的数据“线性”地存储到物理空间中,这种存储结构就称为线性存储结构,简称线性表。

注意:使用线性表存储的数据,要求数据类型必须一致,线性表存储的数据,要么全不都是整形,要么全部都是字符串。一半是整形,另一半是字符串的一组数据无法使用线性表存储。

线性表存储数据可以分为:

顺序存储结构和链式存储结构

数据结构中,一组数据中的某一元素的左侧相邻元素称为“直接前驱”,位于此元素左侧的所有元素都统称为“前驱元素”;某一元素的右侧相邻元素称为“直接后继”,位于此元素右侧的所有元素都统称为“后继元素”;

先介绍顺序表

顺序表全名顺序存储结构,顺序表存储数据时,会提前申请一整块足够大小的物理空间,然后将数据依次存储起来,存储时做到数据元素之间是不间断的。

顺序表的初始化

顺序表除了要申请足够大小的物理空间还需要申请顺序表的存储容量,顺序表的长

度,也就是顺序表中元素的个数。

注意:顺序表申请的存储容量要大于顺序表的长度。

首先我们得自定义顺序表

 typedef struct SeqList{
int * head;//声明了一个名为head的长度不确定的数组,也叫“动态数组”
int length;//记录当前顺序表的长度
int size;//记录顺序表分配的存储容量
}sqlt;

接着初始化顺序表的主要工作:

给 head 动态数据申请足够大小的物理空间

给 size 和 length 赋初值

 #define Size 5
sqlt init_SeqList(){
sqlt s;
s.head=(int*)malloc(sizeof(int)*Size);
//构造一个空的顺序表,动态申请存储空间
if(!s.head)//如果申请失败,作出提示并直接退出程序
{
printf("初始化失败\n");
exit();
}
s.length=;//空表的长度初始化为0
s.size=Size;//空表的初始存储空间为Size
return s;
}

顺序表插入元素

通过遍历,找到数据元素要插入的位置

将要插入位置元素以及后续的元素整体向后移动一个位置;

将元素放到腾出来的位置上

 //插入函数,其中,elem为插入的元素,p为插入到顺序表的位置
sqlt insert_SeqList(sqlt s,int elem,int p)
{
//判断插入本身是否存在问题(如果插入元素位置比整张表的长度+1还大(如果相等,是尾随的情况),或者插入的位置本身不存在,程序作为提示并自动退出)
if(p>s.length+||p<){
printf("插入的位置有问题\n");
return s;
}
//做插入操作时,首先需要看顺序表是否有多余的存储空间提供给插入的元素,如果没有,需要申请
if(s.length>=s.size){
s.head=(int *)realloc(s.head,(s.size+)*sizeof(int));
if(!s.head){
printf("存储分配失败\n");
}
}
//插入操作,需要将从插入位置开始的后续元素,逐个后移
for(int i=s.length-;i>=p-;i--){
s.head[i+]=s.head[i];
}
//后移完成后,直接将所需插入元素,添加到顺序表的相应位置
s.head[p-]=elem;
s.length++;//由于添加了元素,所以长度+1
return s;
}

注意,动态数组额外申请更多物理空间使用的是 realloc 函数。并且,在实现后续元素整体后移的过程,目标位置其实是有数据的,还是原来的数字,只是下一步新插入元素时会把旧元素直接覆盖。

顺序表删除元素

只需找到目标元素,并将其后续所有元素整体前移 1 个位置即可。(后续元素整体前移一个位置,会直接将目标元素删除,可间接实现删除元素的目的。)

 sqlt del_SeqList(sqlt s,int p){
if(p>s.length||p<){
printf("被删除的元素有误\n");
return s;
}
//删除操作
for(int i=p;i<s.length;i++){
s.head[i-]=s.head[i];
}
s.length--;//删除一个元素表的长度要减1
return s;
}

顺序表查找元素

在这里只选择简单的顺序查找算法

 //查找函数,其中,elem表示要查找的数据元素的值
int select_SeqList(sqlt s, int elem){
for(int i=;i<s.length;i++){
if(s.head[i]==elem){
return i+;
}
}
return -;//如果查找失败,返回-1
}

顺序表更改元素

找到目标元素;

直接修改该元素的值;

 //更改函数,其中,elem为要更改的元素,newElem为新的数据元素
sqlt amend_SeqList(sqlt s, int elem, int newElem){
int p=select_SeqList(s,elem);
s.head[p-]=newElem;
//由于返回的是元素在顺序表中的位置,所以p-1就是该元素在数组中的下标
return s;
}

以下实现增删改查的整体顺序存储结构线性表

 #include <stdio.h>
#include <stdlib.h> #define Size 5
typedef struct SeqList{
int * head;//声明了一个名为head的长度不确定的数组,也叫“动态数组”
int length;//记录当前顺序表的长度
int size;//记录顺序表分配的存储容量
}sqlt;
sqlt init_SeqList(){
sqlt s;
s.head=(int*)malloc(sizeof(int)*Size);
//构造一个空的顺序表,动态申请存储空间
if(!s.head)//如果申请失败,作出提示并直接退出程序
{
printf("初始化失败\n");
exit();
}
s.length=;//空表的长度初始化为0
s.size=Size;//空表的初始存储空间为Size
return s;
}
//插入函数,其中,elem为插入的元素,p为插入到顺序表的位置
sqlt insert_SeqList(sqlt s,int elem,int p)
{
//判断插入本身是否存在问题(如果插入元素位置比整张表的长度+1还大(如果相等,是尾随的情况),或者插入的位置本身不存在,程序作为提示并自动退出)
if(p>s.length+||p<){
printf("插入的位置有问题\n");
return s;
}
//做插入操作时,首先需要看顺序表是否有多余的存储空间提供给插入的元素,如果没有,需要申请
if(s.length>=s.size){
s.head=(int *)realloc(s.head,(s.size+)*sizeof(int));
if(!s.head){
printf("存储分配失败\n");
}
}
//插入操作,需要将从插入位置开始的后续元素,逐个后移
for(int i=s.length-;i>=p-;i--){
s.head[i+]=s.head[i];
}
//后移完成后,直接将所需插入元素,添加到顺序表的相应位置
s.head[p-]=elem;
s.length++;//由于添加了元素,所以长度+1
return s;
}
sqlt del_SeqList(sqlt s,int p){
if(p>s.length||p<){
printf("被删除的元素有误\n");
return s;
}
//删除操作
for(int i=p;i<s.length;i++){
s.head[i-]=s.head[i];
}
s.length--;//删除一个元素表的长度要减1
return s;
}
//查找函数,其中,elem表示要查找的数据元素的值
int select_SeqList(sqlt s, int elem){
for(int i=;i<s.length;i++){
if(s.head[i]==elem){
return i+;
}
}
return -;//如果查找失败,返回-1
}
//更改函数,其中,elem为要更改的元素,newElem为新的数据元素
sqlt amend_SeqList(sqlt s, int elem, int newElem){
int p=select_SeqList(s,elem);
s.head[p-]=newElem;
//由于返回的是元素在顺序表中的位置,所以p-1就是该元素在数组中的下标
return s;
}
//输出顺序表中元素的函数
void display_SeqList(sqlt s){
for(int i=; i<s.length; i++){
printf("%d",s.head[i]);
}
printf("\n");
} int main(){
sqlt s1=init_SeqList();
//向顺序表中添加元素
for(int i=;i<=Size;i++){
s1.head[i-]=i;
s1.length++;
}
printf("原顺序表:\n");
display_SeqList(s1); printf("删除元素2:\n");
s1=del_SeqList(s1,);
display_SeqList(s1); printf("在第3的位置插入元素5:\n");
s1=insert_SeqList(s1,,);
s1=insert_SeqList(s1,,);
s1=insert_SeqList(s1,,);
s1=insert_SeqList(s1,,);
display_SeqList(s1); printf("查找元素3的位置:\n");
int p=select_SeqList(s1,);
printf("%d\n",p); printf("将元素3改为6:\n");
s1=amend_SeqList(s1,,);
display_SeqList(s1);
return ;
}

c语言数据结构之线性表的顺序存储结构的更多相关文章

  1. 【Java】 大话数据结构(1) 线性表之顺序存储结构

     本文根据<大话数据结构>一书,实现了Java版的顺序存储结构. 顺序存储结构指的是用一段地址连续的存储单元一次存储线性表的数据元素,一般用一维数组来实现. 书中的线性表抽象数据类型定义如 ...

  2. 数据结构之线性表的顺序存储结构的实现--C语言版

    #include <stdio.h> #include <stdlib.h> #include <time.h> #define INIT_SIZE 100 #de ...

  3. 数据结构4:顺序表(线性表的顺序存储结构)及C语言实现

    逻辑结构上呈线性分布的数据元素在实际的物理存储结构中也同样相互之间紧挨着,这种存储结构称为线性表的顺序存储结构. 也就是说,逻辑上具有线性关系的数据按照前后的次序全部存储在一整块连续的内存空间中,之间 ...

  4. c数据结构 -- 线性表之 顺序存储结构 于 链式存储结构 (单链表)

    线性表 定义:线性表是具有相同特性的数据元素的一个有限序列 类型: 1:顺序存储结构 定义:把逻辑上相邻的数据元素存储在物理上相邻的存储单元中的存储结构 算法: #include <stdio. ...

  5. 2.2_线性表的顺序存储结构_参考集合ArrayList

    [线性表的顺序存储从结构] 指的是用一段连续的存储单元一次储存线性表的数据元素. [线性表的顺序存储的结构代码 C语言版] #define MAXSIZE 20 /*存储空间初始分配量*/ typed ...

  6. 线性表的顺序存储结构——java

    线性表的顺序存储结构:是指用一组地址连续的存储单元一次存放线性表的元素.为了使用顺序结构实现线性表,程序通常会采用数组来保存线性中的元素,是一种随机存储的数据结构,适合随机访问.java中ArrayL ...

  7. C++编程练习(1)----“实现简单的线性表的顺序存储结构“

    线性表的顺序存储结构,指的是用一段地址连续的存储单元依次存储线性表的数据元素. 故可以用数组来实现顺序存储结构. 用C++编写的利用数组实现简单的读取.插入和删除功能的线性表. #include< ...

  8. 线性表的顺序存储结构之顺序表类的实现_Java

    在上一篇博文——线性表接口的实现_Java中,我们实现了线性表的接口,今天让我们来实现线性表的顺序存储结构——顺序表类. 首先让我们来看下顺序表的定义: 线性表的顺序存储是用一组连续的内存单元依次存放 ...

  9. 线性表之顺序存储结构(C语言动态数组实现)

    线性表的定义:N个数据元素的有限序列 线性表从存储结构上分为:顺序存储结构(数组)和 链式存储结构(链表) 顺序存储结构:是用一段连续的内存空间存储表中的数据 L=(a1,a2,a3....an) 链 ...

随机推荐

  1. Object.freeze

    Object.freeze() 方法可以冻结一个对象.一个被冻结的对象再也不能被修改:冻结了一个对象则不能向这个对象添加新的属性,不能删除已有属性,不能修改该对象已有属性的可枚举性.可配置性.可写性, ...

  2. APS助众生药业突破运营管理瓶颈

    众生药业一直致力于为了世界提供世界级的产品及服务,成立以来公司先后实施了ERP系统,CRM系统,WMS系统,OA系统,精益生产,朝着行业信息化水平领先的目标迈进. 但近年随着业务量的不断扩大,仅仅拥有 ...

  3. android studio学习---Lint工具

    对代码进行测试是一回事,但同样重要的是.我们还需要在编写代码的同时引入各种最佳实践.这不仅能够显著改进性能表现,也能增加应用程序的整体稳定性.另外,经过合理结构调整的项目在维护方面也更为轻松. And ...

  4. linux中find命令的使用详解(转载)

    常用命令 find  (目录)   [-type d | f]  (文件夹 | 文件)   -name   (名称,可使用正则表达式) find  /root  -name "*core&q ...

  5. 160--Intersection Of Two Linked List

    public class IntersectionOfTwoLinkedList { /* 解法一:暴力遍历求交点. 时间复杂度:O(m*n) 空间复杂度:O(1) */ public ListNod ...

  6. Docker安装Redis4.0

    docker pull redis:4.0 拉取Redis4.0镜像 docker images 查看本地的镜像 mkdir -p /root/redis4.0/data 在宿主机创建数据文件目录 w ...

  7. linux突然不能上网,eth0网卡消失

    情况:之前可以正常浏览网页,没有动其它的地方,浏览器突然不能上网 ifconfig # 发现eth0网卡不见了,只有lo卡 ifconfig -a # 发现了eth0,但是没有IP地址 dhclien ...

  8. MarkDown中如何加入上标和下标

    上标 使用<sup></sup>标签包裹的部分就是上标,例如:A<sup>T</sup> 显示效果就是 AT . 下标 使用<sub>< ...

  9. django 基础进阶ORM COOKIE

    ORM: class Book(models.Model): title=models.CharFiled(max_length=32) 类-----------------表    #  Book- ...

  10. 如何将MultipartFile转换成based4

    public String test(MultipartFile file) throws Exception{ BASE64Encoder base64Encoder =new BASE64Enco ...