线性表(二)

线性表的链式存储结构

单链表

  • 单链表的存储结构
tydedef struct Node{
    ElemTytpe data;
    struct Node *next;
}Node;
typedef struct Node *LinkList;/*定义LinkList*/
  • 初始化顺序线性表
Status InitList(LinkList *L){
    *L=(LinkList)malloc(sizeof(Node)); /* 产生头结点,并使L指向此头结点 */
    if(!(*L)) /* 存储分配失败 */
            return ERROR;
    (*L)->next=NULL; /* 指针域为空 */

    return OK;
}
  • 获取线性表中第i个数据元素的值
Status GetElem(LinkList L,int i,ElemType *e)
{
    int j;
    LinkList p;     /* 声明一结点p */
    p = L->next;        /* 让p指向链表L的第一个结点 */
    j = 1;      /*  j为计数器 */
    while (p && j<i)  /* p不为空或者计数器j还没有等于i时,循环继续 */
    {   
        p = p->next;  /* 让p指向下一个结点 */
        ++j;
    }
    if ( !p || j>i ) 
        return ERROR;  /*  第i个元素不存在 */
    *e = p->data;   /*  取第i个元素的数据 */
    return OK;
}
  • 在线性表中第i个位置插入新的数据元素e
Status ListInsert(LinkList *L,int i,ElemType e)
{ 
    int j;
    LinkList p,s;
    p = *L;   
    j = 1;
    while (p && j < i)     /* 寻找第i个结点 */
    {
        p = p->next;
        ++j;
    } 
    if (!p || j > i) 
        return ERROR;   /* 第i个元素不存在 */
    s = (LinkList)malloc(sizeof(Node));  /*  生成新结点(C语言标准函数) */
    s->data = e;  
    s->next = p->next;      /* 将p的后继结点赋值给s的后继  */
    p->next = s;          /* 将s赋值给p的后继 */
    return OK;
}
  • 删除线性表中第i个数据元素
Status ListDelete(LinkList *L,int i,ElemType *e) 
{ 
    int j;
    LinkList p,q;
    p = *L;
    j = 1;
    while (p->next && j < i)    /* 遍历寻找第i个元素 */
    {
        p = p->next;
        ++j;
    }
    if (!(p->next) || j > i) 
        return ERROR;           /* 第i个元素不存在 */
    q = p->next;
    p->next = q->next;          /* 将q的后继赋值给p的后继 */
    *e = q->data;               /* 将q结点中的数据给e */
    free(q);                    /* 让系统回收此结点,释放内存 */
    return OK;
}
  • 依次输出线性表中的每个元素
Status ListTraverse(LinkList L)
{
    LinkList p=L->next;
    while(p)
    {
        visit(p->data);
        p=p->next;
    }
    printf("\n");
    return OK;
}
  • 随机产生n个元素值 建立带表头结点的单链线性表(头差法 )
void CreateListHead(LinkList *L, int n) 
{
    LinkList p;
    int i;
    srand(time(0));                         /* 初始化随机数种子 */
    *L = (LinkList)malloc(sizeof(Node));
    (*L)->next = NULL;                      /*  先建立一个带头结点的单链表 */
    for (i=0; i<n; i++) 
    {
        p = (LinkList)malloc(sizeof(Node)); /*  生成新结点 */
        p->data = rand()%100+1;             /*  随机生成100以内的数字 */
        p->next = (*L)->next;    
        (*L)->next = p;                     /*  插入到表头 */
    }
}
  • 随机产生n个元素值,建立带表头结点的单链线性表(尾插法)
void CreateListTail(LinkList *L, int n) 
{
    LinkList p,r;
    int i;
    srand(time(0));                      /* 初始化随机数种子 */
    *L = (LinkList)malloc(sizeof(Node)); /* L为整个线性表 */
    r=*L;                                /* r为指向尾部的结点 */
    for (i=0; i<n; i++) 
    {
        p = (Node *)malloc(sizeof(Node)); /*  生成新结点 */
        p->data = rand()%100+1;           /*  随机生成100以内的数字 */
        r->next=p;                        /* 将表尾终端结点的指针指向新结点 */
        r = p;                            /* 将当前的新结点定义为表尾终端结点 */
    }
    r->next = NULL;                       /* 表示当前链表结束 */
}
(1)顺序存储结构的线性表可以用数组来实现,插入一个元素时,需要将插入位置后面的元素都向后移动一位,然后将要插入的元素放在出来的位置上。 具体实现步骤如下: 1. 判断线性表是否已满,如果已满,则无法插入,返回插入失败。 2. 如果线性表未满,则根据插入位置,将插入位置后面的元素都向后移动一位,腾出插入位置。 3. 将要插入的元素放在出来的位置上。 (2)链式存储结构的线性表可以用链表来实现,删除一个结点时,需要找到要删除的结点的前一个结点,然后将前一个结点的 next 指针指向要删除结点的下一个结点,最后释放要删除的结点的内存。 具体实现步骤如下: 1. 遍历链表,找到要删除的结点的前一个结点。 2. 将前一个结点的 next 指针指向要删除结点的下一个结点。 3. 释放要删除的结点的内存。 (3)栈和队列都是一种特殊的线性表者的区别在于元素的存储和取出顺序不同。 栈是一种后进先出(Last In First Out,LIFO)的数据结构,只能在栈顶进行插入和删除操作。栈的入栈操作相当于在栈顶插入一个元素,出栈操作相当于从栈顶删除一个元素。 队列是一种先进先出(First In First Out,FIFO)的数据结构,只能在队尾插入元素,在队头删除元素。入队操作相当于在队尾插入一个元素,出队操作相当于从队头删除一个元素。 具体实现步骤如下: 1. 创建栈或队列,可以使用数组或链表来实现。 2. 对于栈,入栈操作需要将要插入的元素放在栈顶,出栈操作需要从栈顶删除一个元素。 3. 对于队列,入队操作需要将要插入的元素放在队尾,出队操作需要从队头删除一个元素
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值