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

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

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

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

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

先介绍顺序表

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

顺序表的初始化

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

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

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

首先我们得自定义顺序表

 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. c# 根据域名的到对应的IP

    今天做了域名解析,由于项目里要用到域名对应的ip 所以做了这个小程序 private void button_Net_Click(object sender, EventArgs e)        ...

  2. .net web api 权限验证

    做一个登录权限验证. 开始吧. using System; using System.Collections.Generic; using System.Drawing; using System.D ...

  3. logger(二)logback简介及其实现原理

    一.logback简介 logback是log4j创始人写的,性能比log4j要好,目前主要分为3个模块 logback-core:核心代码模块 logback-classic:log4j的一个改良版 ...

  4. 2.redis 和 memcached 有什么区别?redis 的线程模型是什么?为什么 redis 单线程却能支撑高并发?

    作者:中华石杉 面试题 redis 和 memcached 有什么区别?redis 的线程模型是什么?为什么 redis 单线程却能支撑高并发? 面试官心理分析 这个是问 redis 的时候,最基本的 ...

  5. 安装docker后,导致qemu的桥接网络出现问题

    按照Qemu-4.1 桥接网络设置中介绍的方法建立起桥接网络后,可以实现虚拟机和host的相互ping,但是在虚拟机里去ping其他跟host处于同一个网段的ip地址时却失败了,然后ifconfig后 ...

  6. python类定义的讲解

    python是怎么定义类的,看了下面的文章大家就会了,不用多说,开始学习. 一.类定义: 复制代码代码如下: class <类名>: <语句> 类实例化后,可以使用其属性,实际 ...

  7. python 数据库小测试

    1.整理博客 2.详细解释下列mysql执行语句的每个参数与参数值的含义 ​ mysql -hlocalhost -P3306 -uroot -proot # mysql (连接数据库) # hloc ...

  8. java任务调度之Timer定时器

    定时器相信大家都不陌生,平时使用定时器就像使用闹钟一样,我们可以在固定的时间做某件事,也可以在固定的时间段重复做某件事,今天就来分析一下java中自带的定时任务器Timer. 一.Timer基本使用 ...

  9. 开始Golang之旅了

  10. [RN]react-native-scrollable-tab-view和FlatList手势冲突解决

    问题描述: react-native-scrollable-tab-view叠加react-native-scrollable-tab-view再加上FlatList FlatList向下拉时,会造成 ...