⽤c语⾔编程实现⼀个顺序表,C语⾔实现顺序表基本操作汇总#include
#include
#define TRUE 1
#define FALSE 0
#define OK 1
#define ERROR 0
#define OVERFLOW -2
#define LIST_INIT_SIZE 100
#define LISTINCREMENT 10
typedef int status ;
typedef int ElemType ;
typedef struct{
ElemType *elem;
int length,listsize;
}SqList;
status InitList(SqList &L)//初始化
{
L.elem=(ElemType *)malloc(LIST_INIT_SIZE*sizeof(ElemType));
if(!L.elem) exit(OVERFLOW);
L.listsize=LIST_INIT_SIZE;
L.length=0;
return OK;
}
status Build(SqList &L)//建⽴表
{
int i,n;
printf("请输⼊元素个数n和n个元素\n");
scanf("%d",&n);
if(n>LIST_INIT_SIZE)//如果n⼤于当前空间
{
L.elem=(ElemType *)realloc(L.elem,(n+LISTINCREMENT)*sizeof(ElemType));
if(!L.elem) exit(OVERFLOW);
L.listsize=n+LISTINCREMENT;
}
for(i=0;i
scanf("%d",L.elem+i);
L.length=n;
return OK;
}
void Print(SqList &L)//输出表中元素和长度c语言listinsert函数
{
int i;
for(i=0;i
printf("%d ",*(L.elem+i));
printf("\n长度为:%d\n\n",L.length);
}
void Tips()//提⽰函数
{
printf("请选择你的想要的操作:\n");
printf("<1> 输出顺序表及顺序表的长度\n");
printf("<2> 删除值为x的结点\n");
printf("<3> 删除给定位置i的结点\n");
printf("<4> 将顺序表逆置\n");
printf("<5> 将顺序表按升序排序\n");
printf("<6> 将x插⼊到顺序表的适当位置上\n");
printf("<7> 将两个有序表合并\n");
printf("<0> 退出\n\n");
}
status ListDelete1(SqList &L,int x)//删除值为X的元素{
int i;
for(i=0;i
if(*(L.elem+i)==x)
break;
if(i==L.length)
return ERROR;
for(i++;i
*(L.elem+i-1)=*(L.elem+i);
L.length--;
return OK;
}
status ListDelete2(SqList &L,int x)//删除第X个元素{
int i;
if(x<0||x>=L.length)
return ERROR;
for(i=x+1;i
*(L.elem+i-1)=*(L.elem+i);
L.length--;
return OK;
}
void Inverse(SqList &L)//逆置函数
{
int i,t;
for(i=0;i
{
t=*(L.elem+i);
*(L.elem+i)=*(L.elem+L.length-i-1);
*(L.elem+L.length-i-1)=t;
}
}
void Sort(SqList &L)//冒泡排序(升序)
{
int i,j,t;
for(i=1;i
for(j=0;j
{
if(*(L.elem+j)>*(L.elem+j+1))
{
t=*(L.elem+j);
*(L.elem+j)=*(L.elem+j+1);
*(L.elem+j+1)=t;
}
}
printf("已按升序排列\n\n");
}
status ListInsert(SqList &L,int x)//将X插⼊,使仍然有序
{
int i,k;
if(L.length>=L.listsize)
{
L.elem=(ElemType *)realloc(L.elem,(L.listsize+LISTINCREMENT)*sizeof(ElemType));
if(!L.elem) exit(OVERFLOW);
L.listsize+=LISTINCREMENT;
}
for(i=0;i
if(x
break;
k=i;
for(i=L.length;i>k;i--)
*(L.elem+i)=*(L.elem+i-1);
*(L.elem+k)=x;
L.length++;
return OK;
}
status Merger(SqList &L,SqList &Lb)//合并两个线性表
{
int i,j,k;
SqList Lc;
InitList(Lc);
if(Lc.listsize
{
Lc.elem=(ElemType *)realloc(Lc.elem,(L.length+Lb.length+LISTINCREMENT)*sizeof(ElemType)); if(!L.elem) exit(OVERFLOW);
Lc.listsize=L.length+Lb.length+LISTINCREMENT;
}
i=j=k=0;
while(i
{
if(*(L.elem+i) < *(Lb.elem+j)) {
*(Lc.elem+k)=*(L.elem+i);
k++;i++;
}
else
{
*(Lc.elem+k)=*(Lb.elem+j);
k++;j++;
}
}
while(i
{
*(Lc.elem+k)=*(L.elem+i);
k++;i++;
}
while(j
{
*(Lc.elem+k)=*(Lb.elem+j);
k++;j++;
}
Lc.length=L.length+Lb.length; L=Lc;
return OK;
}
int main()
{
int op,x,flag;
SqList L,Lb;
InitList(L);
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论