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

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

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

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

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

先介绍顺序表

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

顺序表的初始化

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

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

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

首先我们得自定义顺序表

 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. day 48

    目录 js BOM(浏览器对象模型) window对象 window子对象 弹出框 计时事件 DOM(文档对象模型) 查找标签 节点操作 事件 常用事件 绑定方式 jQuery jQuery介绍 jQ ...

  2. Android源码分析(十七)----init.rc文件添加脚本代码

    一:init.rc文件修改 开机后运行一次: chmod 777 /system/bin/bt_config.sh service bt_config /system/bin/bt_config.sh ...

  3. org.json package

    JSON is a light-weight,language independent,data interchange format. org.json package implement JSON ...

  4. 解决postMessage跨域问题

    在HTML5中新增了postMessage方法,postMessage可以实现跨文档消息传输(Cross Document Messaging),Internet Explorer 8, Firefo ...

  5. C++小工具

    1.Doxygen 从源代码生成文档.可以生成在线文档(HTML)和离线手册(以LATEX格式),还可以自动生成各种依赖关系图,继承关系图等.

  6. Mybatis-plus中如何排除非表字段的三种方式

    1.transient关键字 2.使用静态变量(static) 3.TableField(exit=false) 这三种方式可以在使用的过程中,是这个对象中的属性不被序列化.(直接被忽略)

  7. AtCoder Grand Contest 033 题解

    传送门 我比赛的时候怕不是在睡觉啊-- \(A\ Darker\ and\ Darker\) 我是不是想得太复杂了--根本没必要像我这样做吧-- 首先问题可以转化成令\(p_{i,j}\)表示到\(( ...

  8. MapReduce 程序mysql JDBC驱动类找不到原因及学习hadoop写入数据到Mysql数据库的方法

    报错 :ClassNotFoundException: com.mysql.jdbc.Driver 需求描述: hadoop需要动态加载个三方jar包(比如mysql JDBC 驱动包),是在MR结束 ...

  9. q1096

    一,看题 1,大概是每个点都来一次BFS标记下应该就可以. 2,你可以想想队列为啥pop()是l++; 3,还是字符你得注意下. 4,x,y,m,n,行列你得搞清楚. 5,这棋盘的破东西.. 6,额, ...

  10. Console工程下如何不显示控制台黑窗口只显示Windows窗口

    原文地址https://www.cnblogs.com/smiler/p/4575052.html OpenGL,绘制图形的时候,如果不进行设置,运行的时候会先出现黑窗口再出现Windows窗口. 其 ...