c语言数据结构之线性表的顺序存储结构
线性表,即线性存储结构,将具有“一对一”关系的数据“线性”地存储到物理空间中,这种存储结构就称为线性存储结构,简称线性表。
注意:使用线性表存储的数据,要求数据类型必须一致,线性表存储的数据,要么全不都是整形,要么全部都是字符串。一半是整形,另一半是字符串的一组数据无法使用线性表存储。
线性表存储数据可以分为:
顺序存储结构和链式存储结构
数据结构中,一组数据中的某一元素的左侧相邻元素称为“直接前驱”,位于此元素左侧的所有元素都统称为“前驱元素”;某一元素的右侧相邻元素称为“直接后继”,位于此元素右侧的所有元素都统称为“后继元素”;
先介绍顺序表
顺序表全名顺序存储结构,顺序表存储数据时,会提前申请一整块足够大小的物理空间,然后将数据依次存储起来,存储时做到数据元素之间是不间断的。
顺序表的初始化
顺序表除了要申请足够大小的物理空间还需要申请顺序表的存储容量,顺序表的长
度,也就是顺序表中元素的个数。
注意:顺序表申请的存储容量要大于顺序表的长度。
首先我们得自定义顺序表
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语言数据结构之线性表的顺序存储结构的更多相关文章
- 【Java】 大话数据结构(1) 线性表之顺序存储结构
本文根据<大话数据结构>一书,实现了Java版的顺序存储结构. 顺序存储结构指的是用一段地址连续的存储单元一次存储线性表的数据元素,一般用一维数组来实现. 书中的线性表抽象数据类型定义如 ...
- 数据结构之线性表的顺序存储结构的实现--C语言版
#include <stdio.h> #include <stdlib.h> #include <time.h> #define INIT_SIZE 100 #de ...
- 数据结构4:顺序表(线性表的顺序存储结构)及C语言实现
逻辑结构上呈线性分布的数据元素在实际的物理存储结构中也同样相互之间紧挨着,这种存储结构称为线性表的顺序存储结构. 也就是说,逻辑上具有线性关系的数据按照前后的次序全部存储在一整块连续的内存空间中,之间 ...
- c数据结构 -- 线性表之 顺序存储结构 于 链式存储结构 (单链表)
线性表 定义:线性表是具有相同特性的数据元素的一个有限序列 类型: 1:顺序存储结构 定义:把逻辑上相邻的数据元素存储在物理上相邻的存储单元中的存储结构 算法: #include <stdio. ...
- 2.2_线性表的顺序存储结构_参考集合ArrayList
[线性表的顺序存储从结构] 指的是用一段连续的存储单元一次储存线性表的数据元素. [线性表的顺序存储的结构代码 C语言版] #define MAXSIZE 20 /*存储空间初始分配量*/ typed ...
- 线性表的顺序存储结构——java
线性表的顺序存储结构:是指用一组地址连续的存储单元一次存放线性表的元素.为了使用顺序结构实现线性表,程序通常会采用数组来保存线性中的元素,是一种随机存储的数据结构,适合随机访问.java中ArrayL ...
- C++编程练习(1)----“实现简单的线性表的顺序存储结构“
线性表的顺序存储结构,指的是用一段地址连续的存储单元依次存储线性表的数据元素. 故可以用数组来实现顺序存储结构. 用C++编写的利用数组实现简单的读取.插入和删除功能的线性表. #include< ...
- 线性表的顺序存储结构之顺序表类的实现_Java
在上一篇博文——线性表接口的实现_Java中,我们实现了线性表的接口,今天让我们来实现线性表的顺序存储结构——顺序表类. 首先让我们来看下顺序表的定义: 线性表的顺序存储是用一组连续的内存单元依次存放 ...
- 线性表之顺序存储结构(C语言动态数组实现)
线性表的定义:N个数据元素的有限序列 线性表从存储结构上分为:顺序存储结构(数组)和 链式存储结构(链表) 顺序存储结构:是用一段连续的内存空间存储表中的数据 L=(a1,a2,a3....an) 链 ...
随机推荐
- 前端H5知识总结
两年大专生活匆匆而过,身边的朋友也都各奔东西,9月份开始实习感觉自己的前端功底有所欠缺,这个暑假除了打工我还有一个半月的学习时间希望自己能够充分利用这段时间.7月3号所学知识在此做以下总结以便自己复习 ...
- Spring cloud简单学习总结
微服务简介 一.spring boot和spring cloud 的关系 spring boot来写各个拆分出来的微服务,spring cloud把各个微服务联系起来,比如各个微服务通过eurke找 ...
- Js中replace替换所有*
var t = '***感**谢**有**你***'; var r = t.replace(/\*/g,''); //\为转义字符 g表示全局 console.log(r) //感谢有你
- intellij idea 新建springboot工程pom.xml报错
今天使用idea新建的springboot工程pom.xml文件报错如下 1. 问题 'settings.xml' has syntax errors less... (Ctrl+F1) Inspec ...
- Python3和HTMLTestRunner生成html测试报告
1.测试环境: Python3.5+unittest+HTMLTestRunner 2.下载HTMLTestRunner.py文件 下载地址 http://tungwaiyip.info/softwa ...
- 极简让ingress-nginx最新版(0.25.0)跑起来
裸步骤: 一,manadatory.yaml apiVersion: v1 kind: Namespace metadata: name: ingress-nginx labels: app.kube ...
- HDU5126 stars(cdq分治)
传送门 题意: 先有两种操作,插入和查询,插入操作则插入一个点\((x,y,z)\),查询操作给出两个点\((x_1,y_1,z_1),(x_2,y_2,z_2)\),回答满足\(x_1\leq x\ ...
- 06-C#笔记-常量
1. 进制 前缀:0x 或 0X 表示十六进制,0 表示八进制,没有前缀则表示十进制. 后缀:可以是 U 或 L 的组合,其中,U 和 L 分别表示 unsigned 和 long.后缀可以是大写或者 ...
- 26 配置TensorFlow 1.9
https://www.ctolib.com/topics-133854.html sudo apt install libatlas-base-dev pip3 install tensorflow ...
- NodeJS模块和ES6模块系统语法及注意点
社区模块规范: 1.CommonJS规范 规范实现者: NodeJS 服务端 Browserify 浏览器 2.AMD规范 全称 异步模块定义 规范实现者: RequireJS 浏览器 3.CMD规范 ...