moc 发表于 2018-9-23 17:01:10

003-线性表的链式存储

1、基本概念
链式存储结构:为了表示每个数据元素与其直接后继元素之间的逻辑关系,每个元素除了存储本身的信息以外,还需要存储指示其直接后继元素的信息。
n个结点(ai的存储映像)链结成一个链表,即线性表的链式存储结构,因此链表中每个结点需要包含一个指针域,即单链表。

2、内核链表
相比于传统链表,Linux内核链表实现了链表的算法和具体的业务结点的分离。详细参考:传送门

3、设计与实现
强调:
        ① 指针指向谁就把谁的地址赋给指针;
        ② 分清链表的操作逻辑 和 辅助指针变量之间的关系。
1. 插入元素

        ① 让辅助指针current指向插入元素的位置,辅助指针初始指向头指针,只需向后以插入的位置号即可;
        ② 让node连接后续链表==> node->next = current->next;
        ③ 让前面链表 连接新的node结点 ==> current->next = node.
int LinkList_Insert(LinkList* list, LinkListNode* node, int pos)
{
        int ret = 0, i = 0;
        TLinkList *tList = NULL;
        LinkListNode *current = NULL;
        if (list == NULL || node == NULL || pos < 0)
        {
                ret = -1;
                printf("Fun LinkList_Insert() paramter error!");
                return ret;
        }

        tList = (TLinkList*)list;
        current = &(tList->header);// 辅助指针指向链表头部

        for (i = 0; i < pos && (current->next != NULL); i++)
        {
                current = current->next;
        }

        // 1 让node连接后续链表
        node->next = current->next;
        // 2 让前面链表 连接新的node结点
        current->next = node;

        tList->length++;
        return 0;
}
2. 删除元素

        ① 让辅助指针current指向删除元素的前一个位置,辅助指针初始指向头指针,只需向后以插入的位置号即可;
        ② 缓存被删除的结点位置 ==> ret = current->next;
        ③ 指向后一个结点 ==>current->next = ret->next.
LinkListNode* LinkList_Delete(LinkList* list, int pos)
{
        int i = 0;
        TLinkList *tList = NULL;
        LinkListNode *current, *ret = NULL;
        if (list == NULL || pos < 0)
        {
                printf("Fun LinkList_Insert() paramter error!");
                return NULL;
        }

        tList = (TLinkList*)list;
        current = &(tList->header);

        for (i = 0; i < pos && (current->next != NULL); i++)
        {
                current = current->next;
        }

        // 缓存被删除的结点位置
        ret = current->next;

        // 指向后一个结点
        current->next = ret->next;

        tList->length--;
        return ret;
}
4、链式结构的优缺点
优点:
        无需一次性定制链表的容量,可动态增减;
        插入和删除操作无需移动数据元素。
缺点:
        数据元素必须保存后继元素的位置信息;
        获取指定数据元素的操作需要访问之前的元素。
完整代码:
页: [1]
查看完整版本: 003-线性表的链式存储