c语言编程文件中删除数据结构,C语言数据结构实战(一)顺序表的插入与删除

本文分享了一篇关于使用C语言实现顺序表插入和删除操作的教程。作者提供了list.c、list.h、stu.h和main.c四个源码文件,详细解释了线性表初始化、内存管理、插入和删除元素的实现过程。代码中包含了错误检查和内存管理,确保了程序的健壮性。
摘要由CSDN通过智能技术生成

今天学习了思成老师的数据结构实战教程 写了一个顺序表 插入和删除的操作 把源码共享给大家 一共包括list.c stu.h main.c list.h   .h文件是头文件 需要引入 具体的功能我都已经在代码中写明了

list.h代码如下:

//线性表的定义在头文件中实现

#ifndef _LIST_H

#define _LIST_H

#define _LIST_INIT_SIZE 10

#define _LIST_INCREME 10

typedef struct

{

ElemType * elem;//首地址

int length;

int size;

}LIST;

LIST *InitList();

void FreeList(LIST *l);

int InsertList(LIST *l,int i,ElemType *e);

int DeleteList(LIST *l,int i);

#endif

list.c代码如下

#include

#include

#include "stu.h"

#include "list.h"

//线性表的初始化,此时数据存储的大小的内存还未开辟 开辟的是list.h的大小

LIST *InitList()

{

LIST *l=(LIST *)malloc(sizeof(LIST));

//判断开辟是否成功

if(l==NULL)

exit(0);

//开辟存储数据的内存的区域

l->elem=(ElemType *)malloc(_LIST_INIT_SIZE *sizeof(ElemType));

//如果开辟成功的话就释放掉内存

if(l->elem==NULL)

{

free(l);

exit(0);

}

//有效长度赋初值为0

l->length=0;

l->size=_LIST_INIT_SIZE;

return l;

}

//释放对区内存的函数

void FreeList(LIST *l)

{

//要先释放成员的空间

free(l->elem);

free(l);

}

//第一个参数要传得是插入哪一个线性表中去 i指位置

int InsertList(LIST *l,int i,ElemType *e)

{

//定义一些指针 指向相应的位置

ElemType *p=NULL,*q=NULL,*newElem=NULL;

if(l==NULL || e==NULL)

return 0;

//i指的是第几个位置 不是下标

if(i<1||i>l->length+1)

return 0;

//if有效长度大于最大的长度的时候 重新开辟一块内存

if(l->length>=l->size)

{

newElem=realloc(l->elem,(l->size+_LIST_INCREME)*sizeof(ElemType));

if(newElem==NULL)

return 0;

l->elem=newElem;

l->size+=_LIST_INCREME;

}

//q指向插入的位置 i-1代表下标

q=&l->elem[i-1];

//指向最后一个有效的数据元素

for(p=&(l->elem[l->length-1]);p>=q;p--)

*(p+1)=*p;

*q=*e;

++l->length;

return 1;

}

int DeleteList(LIST *l,int i)

{

ElemType *p=NULL,*q=NULL;

if(l=NULL)

return 0;

if(i<1|| i>l->length)

return 0;

p=&l->elem[i-1];

q=&l->elem[l->length-1];

for(;p

*p=*(p+1);

--l->length;

return 1;

}

stu.h代码如下

#ifndef _STU_H

#define _STU_H

//定义一个学生的结构体

typedef struct

{

char sno[4];

char name[21];

char sex[3];

int score;

}ElemType;

#endif

main.c代码如下

#include

#include "stu.h"

#include "list.h"

ElemType stu[3]={

{"S101","张三","男",80},

{"S102","小红","女",75},

{"S103","王五","男",90},

};

void main()

{

int i;

LIST *list=NULL;

//通过函数初始化空间

list=InitList();

for(i=0;i<3;i++)

InsertList(list,1,&stu[i]);

DeleteList(list,2);

FreeList(list);

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值