顺序表的基本操作

1.编写一个程序,实现顺序表的各种基本运算,本实验的顺序表元素的类型为char,在主函数中调用顺序表的基本操作完成如下操作:

(1)初始化顺序表L

(2)依次插入a、b、c、d、e

(3)输出顺序表L

(4)输出顺序表L的长度

(5)判断顺序表L是否为空

(6)输出顺序表的第3个元素

(7)输出元素a的逻辑位置

(8)在第4个元素位置上插入元素f

(9)输出顺序表L

(10)删除L的第3个元素

(11)输出顺序表L

(12)释放顺序表L

#include<stdio.h>

#include<malloc.h>

#include<stdbool.h>

#define maxsize 60

typedef char ElemType;

typedef struct {

    ElemType data[maxsize];

    int length;

}sqlist;

//建立

void creatlist(sqlist* L, ElemType a[], int n)

{

    int i;

    L = (sqlist*)malloc(sizeof(sqlist));

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

         L->data[i] = a[i];

    L->length = n;

}

//初始化

sqlist* initlist()

{

    sqlist* L;

    L = (sqlist*)malloc(sizeof(sqlist));

    L->length = 0;

    return L;

}

//元素查找

void czlist(sqlist* L)

{

    int i;

    char e;

    printf("你想要的元素:");

    scanf(" %c", &e);

    for (i = 0; i < L->length; i++)

    {

         if (L->data[i] == e)

             printf("元素%c的位序为%d\n", e, i+1);

        

    }

   

   

}

//按序号查找

void getElem(sqlist* L)

{

    int i;

    printf("您要的元素序号:");

    scanf("%d", &i);

    printf("第%d号的元素的%c\n", i, L->data[i - 1]);

}

//插入

void charulist(sqlist* L)

{

    int i;

    printf("请输入元素总数:");

    scanf("%d", &i);

    printf("你要插入的元素:");

    for (int j = 0; j < i; j++)

    {

         scanf(" %c", &L->data[j]);

         L->length++;

    }

}

void charulist1(sqlist* L)

{

    int i, j;

    printf("你要插入元素的位序:");

    scanf("%d", &j);

    for (i = L->length; i >= j - 1; i--)

    {

         L->data[i + 1] = L->data[i];

    }

    printf("你要插入的元素:");

    scanf(" %c", &L->data[j - 1]);

    L->length = L->length + 1;

}

//删除

void shanchulist(sqlist* L)

{

    int i, j;

    printf("你要删除元素的位序:");

    scanf("%d", &i);

    for (j = (i - 1); j < L->length - 1; j++)

    {

         L->data[j] = L->data[j + 1];

    }

    L->length = L->length - 1;

}

//判空

void listEmpty(sqlist* L)

{

    if (L->length == 0)

    {

         printf("空表\n");

    }

    else

    {

         printf("不是空表!\n");

    }

}

//求长度

void listLength(sqlist* L)

{

    printf("表长为%d\n", L->length);

}

//输出线性表

void listOut(sqlist* L)

{

    int i;

    printf("顺序表:");

    for (i = 0; i < L->length; i++)

         printf("%c ", L->data[i]);

    printf("\n");

}

//销毁

void Destroylist(sqlist* L)

{

    free(L);

}

int main()

{

    sqlist* L;

    L = initlist();

    charulist(L);

    listEmpty(L);

    listLength(L);

    listOut(L);

    getElem(L);

    czlist(L);

    charulist1(L);

    listOut(L);

    shanchulist(L);

    listOut(L);

    Destroylist(L);

    return 0;

}

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
顺序表是一种线性表,它的基本操作包括初始化、插入、删除、查找、遍历等。下面是顺序表基本操作的实现方法: 1. 初始化:顺序表的初始化包括动态分配内存空间和初始化表头信息。具体实现方法如下: ``` Status InitList(SqList &L) { L.elem = (ElemType*)malloc(LIST_INIT_SIZE * sizeof(ElemType)); if (!L.elem) exit(OVERFLOW); L.length = 0; L.listsize = LIST_INIT_SIZE; return OK; } ``` 2. 插入:在顺序表的第i个位置插入元素x,需要将第i个位置及其后面的元素依次后移一位,然后将x插入到第i个位置。具体实现方法如下: ``` Status ListInsert(SqList &L, int i, ElemType x) { if (i < 1 || i > L.length + 1) return ERROR; if (L.length >= L.listsize) { ElemType* newbase = (ElemType*)realloc(L.elem, (L.listsize + LISINCREMENT) * sizeof(ElemType)); if (!newbase) exit(OVERFLOW); L.elem = newbase; L.listsize += LISINCREMENT; } ElemType* q = &(L.elem[i - 1]); for (ElemType* p = &(L.elem[L.length - 1]); p >= q; --p) *(p + 1) = *p; *q = x; ++L.length; return OK; } ``` 3. 删除:删除顺序表的第i个元素,需要将第i+1个位置及其后面的元素依次前移一位,然后将表长减1。具体实现方法如下: ``` Status ListDelete(SqList &L, int i) { if (i < 1 || i > L.length) return ERROR; ElemType* p = &(L.elem[i - 1]); ElemType* q = L.elem + L.length - 1; for (++p; p <= q; ++p) *(p - 1) = *p; --L.length; return OK; } ``` 4. 查找:查找顺序表中值为x的元素,需要依次遍历顺序表中的每个元素,直到找到值为x的元素或者遍历完整个顺序表。具体实现方法如下: ``` int LocateElem(SqList L, ElemType x) { int i; ElemType* p = L.elem; for (i = 1; i <= L.length; ++i, ++p) if (*p == x) return i; return 0; } ``` 5. 遍历:遍历顺序表中的每个元素,可以使用for循环或者while循环实现。具体实现方法如下: ``` void ListTraverse(SqList L) { int i; ElemType* p = L.elem; for (i = 1; i <= L.length; ++i, ++p) printf("%d ", *p); printf("\n"); } ```

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值