顺序表的各种操作(建立,查找,删除,插入等)

原来的发现有点小问题,重新修改了下,在DEV中运行成功。

#include <stdio.h>
#include <stdlib.h>
#define OK 1
#define ERROR 0
typedef int ElemType;
#define LIST_INIT_SIZE 100
#define INCREMENT       10
typedef struct
{
    ElemType *elem;
    int length;
    int listsize;
}Sqlist;

static Sqlist L;
static int e;
int Init_list(Sqlist *L)  //创建
{
    int i,len;
    printf("1.输入顺序表的长度:");
    scanf("%d",&len);
    L->elem = (ElemType *)malloc(LIST_INIT_SIZE * sizeof(ElemType));
    if(!L->elem) 
		return ERROR;
	printf("输入%d个元素,以空格隔开\n",len);
    for(i = 0;i < len;i ++)
        scanf("%d",&L->elem[i]);
    L->length = len;
    L->listsize = LIST_INIT_SIZE;
    return OK;
}
void print_list(Sqlist *L)  //遍历
{
    int i;
	printf("当前表为:");
	if(!Empity(L))
	{
		printf("空表!\n");
		return;
	}
    for(i = 0;i < L->length;i ++)
    printf("%d ",L->elem[i]);
    printf("\n当前表长度为:%d\n",L->length);
}
int Insert(Sqlist *L,int e,int m)  //插入
{
    if(m < 1||m > L->length + 1)
        return ERROR;
    if(L->length > L->listsize)
    {
        ElemType *newbase;
        newbase = (ElemType *)realloc(L->elem,(L->listsize + INCREMENT)*sizeof(ElemType));
        if(!newbase) 
            return ERROR;
        L->elem = newbase;
        L->listsize += INCREMENT;
    }
    ElemType *p,*q;
    q = &(L->elem[m-1]);
    for(p = &( L->elem[L->length-1] ); p >= q ; p --)
        *(p+1) = *p;
    *q = e;
    L->length ++;
    return OK;
}

int Delete(Sqlist *L,int m)   //删除
{
    if(m < 1||m > L->length)  
        return ERROR;
    ElemType *p;
    for(p = &(L->elem[m-1]);p < &(L->elem[L->length-1]);p ++)
    {
        *p = *(p+1);
    }
    free(&(L->elem[L->length - 1]));
    L->length --;
    return OK;
}
int Found(Sqlist *L,int e)  //查找
{
    ElemType i,*p = L->elem;
    for(i = 1; i <= L->length; p ++ ,i ++)
    {
        if(*p == e)
        return i;
    }
    return ERROR;
}
int Empity(Sqlist *L) //判断表是否为空
{
    if(L->length == 0)
		return 0;
    return 1;
}
int clear(Sqlist *L)//清空
{
	L->length = 0;
	return OK;
}
int main()
{
    int i,n,m;
    if(Init_list(&L)==ERROR)
    {
        printf("创建失败!\n");
        return ERROR;
    }
    print_list(&L);
    printf("2.输入要插入元素的个数:");
    scanf("%d",&n);
    printf("输入要插入的元素及插入的位置,以空格隔开:\n");
    for(i = 0; i < n; i ++)
    {
        scanf("%d%d",&e,&m);
        if(!Insert(&L,e,m))
            printf("插入失败,检查数据重新输入\n");
        print_list(&L);
    }
    printf("3.输入要删除的元素个数:");
    scanf("%d",&n);
    for(i = 0; i < n; i ++)
    {
        printf("输入要删除的第%d个元素所在的位置:",i+1);
        scanf("%d",&m);
        if(!Delete(&L,m))
            printf("删除失败,请输入表长度范围内的数\n");
        print_list(&L);
    }

    printf("4.输入要查找的元素个数:");
    scanf("%d",&n);
    printf("输入要查找的元素:");
    int k;
    for(i = 0; i < n; i ++)
    {
        scanf("%d",&e);
        k = Found(&L,e);
        if(k) printf("%d是表中第%d个元素\n",e,k);
        else printf("表中不存在值为%d的元素\n",e);
    }
	print_list(&L);
    printf("-------------------------------------\n");
	if(Empity(&L))
	{
		printf("是否进行清空操作?y/n \n");
		getchar();
		int ch;
		if(ch = getchar() == 'y')
			printf(clear(&L) == 1 ? "清空成功!\n" : "清空失败!\n");
	}
	print_list(&L);
	printf("操作结束!\n");
    system("PAUSE");
    return 0;
}


  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值