C語言實現(xiàn)順序表的插入刪除
更新時間:2022年05月13日 08:39:50 作者:菜雞蘿卜
這篇文章主要介紹了C語言實現(xiàn)順序表的插入刪除,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
首先聲明一個順序表的結構 (數組的第一個元素是0,但是順序表的第一個一般 從1(人為設定)開始)
#include <stdio.h>
#include <stdlib.h>
#define MAXSIZE 10
#define OK 1
#define FALSE 0
typedef int Elemtype;
typedef bool Status;
typedef struct list
{
Elemtype *elem;
int len; //數據個數
int listsize; //順序表長度
}List;listsize代表這個順序表的最大容量,可以隨時擴容len代表在你創(chuàng)建的這個順序表中有幾個有效的數據,總是小于等于listsize

一、初始化順序表屬性
void list_init(List *L)
{
L->elem=(Elemtype *)malloc(MAXSIZE*sizeof(Elemtype));//開辟空間
if(L->elem==NULL)//判斷空間是否開辟成功
{
printf("malloc fail\n");
exit(0);
}
L->len=0; //初始化數據有效數據為0
L->listsize=MAXSIZE; //初始化數組長度為MAXSIZE
}二、順序表的插入
Status list_insert(List *L,int i,Elemtype data)
{
Elemtype *base,*insert,*p;
if(i<1 || i>L->len+1 || L==NULL)
{
printf("位置輸入錯誤\n");
return FALSE;
}
if(L->len > L->listsize)
{
base=(Elemtype *)realloc(L->elem,(L->listsize+MAXSIZE)*sizeof(Elemtype));//動態(tài)擴容
L->elem=base;
L->listsize+=MAXSIZE;//更新順序表大小
}
insert=&(L->elem[i-1]);//目標指針指向要插入的目標地址
//指向最后一個元素的地址
for(p=L->elem + L->len-1;p>=insert;p--)
{
*(p+1)=*p;
}
*insert=data;
L->len++;
return OK;
}
三、刪除
Status delete_list(List *L,int i)
{
ElemType *q,*delete_i;
if(L==NULL||i<0||i>L->len)
return FALSE;
delete_i=&(L->elem[i-1]);//用指針指向要刪除位置的地址
q=L->elem + L->len-1; //q指針指向順序表最后一個位置的地址 首地址加上數組長度就是最后一個元素地址
for(delete_i=delete_i+1;delete_i<=q;++delete_i)//從刪除位置的地址的下一個元素開始,每個往前移動一位
{
*(delete_i-1)=*delete_i; //前一個位置等于后一個
}
L->len--;
return OK;
}
全部程序
#include <stdio.h>
#include <stdlib.h>
#define MAXSIZE 10
#define OK 1
#define FALSE 0
typedef int Elemtype;
typedef bool Status;
typedef struct list
{
Elemtype *elem;
int len;
int listsize;
}List;
void list_init(List *L)
{
L->elem=(Elemtype *)malloc(MAXSIZE*sizeof(Elemtype));//開辟空間
if(L->elem==NULL)//判斷空間是否開辟成功
{
printf("malloc fail\n");
exit(0);
}
L->len=0; //初始化數據有效數據為0
L->listsize=MAXSIZE; //初始化數組長度為MAXSIZE
}
Status list_insert(List *L,int i,Elemtype data)
{
Elemtype *base,*insert,*p;
if(i<1 || i>L->len+1 || L==NULL)
{
printf("位置輸入錯誤\n");
return FALSE;
}
if(L->len > L->listsize)
{
base=(Elemtype *)realloc(L->elem,(L->listsize+MAXSIZE)*sizeof(Elemtype));
L->elem=base;
L->listsize+=MAXSIZE;
}
insert=&(L->elem[i-1]);//目標指針指向要插入的目標地址
//指向最后一個元素的地址
for(p=L->elem + L->len-1;p>=insert;p--)
{
*(p+1)=*p;
}
*insert=data;
L->len++;
return OK;
}
Status list_delete(List *L,int i)
{
Elemtype *aim,*p;
if(i<0 || i>L->len)
{
printf("位置輸入錯誤\n");
return FALSE;
}
aim=&(L->elem[i-1]);//目標指針指向要刪除的目標地址
p=(L->elem+L->len-1); //指向最后一個元素的地址
for(aim=aim+1;aim<=p;++aim) //目標地址滑動刪除
{
*(aim-1)=*aim;
}
L->len--;
return OK;
}
void show_list(List *L)
{
int i;
for(i=0;i<L->len;i++)
{
printf("elem[%d]=%d\n",i+1,L->elem[i]);
}
printf("\n");
}
int main()
{
int i;
List L;
list_init(&L);
for(i=0;i<10;i++)
{
list_insert(&L,i+1,i+1);
}
printf("插入前的順序表\n");
show_list(&L);
printf("插入后的順序表 在5位置插入99\n");
list_insert(&L,5,99);
show_list(&L);
printf("刪除后的順序表 把5位置刪除\n");
list_delete(&L,5);
show_list(&L);
return 0;
}
運行結果如下

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
一文帶你入木三分地理解字符串KMP算法以及C++實現(xiàn)
KMP算法是一種改進的字符串匹配算法,KMP算法的核心是利用匹配失敗后的信息,盡量減少模式串與主串的匹配次數以達到快速匹配的目的。本文就來和大家聊聊KMP算法的原理與實現(xiàn),需要的可以參考一下2022-12-12

