数据结构---双向链表

在单向链表的基础上的扩展

(1)初始化

复制代码
typedef struct Node
{
    int data;
    struct Node *pre;//指向前一个结点
    struct Node *next;//指向后一个结点
}Node,*DoubleLinkList;
//初始化,产出一个头结点
DoubleLinkList InitList(){
    //分配内存
    Node *head = (Node*)malloc(sizeof(Node));
    if(head == NULL)
    {
        printf("内存申请失败\n");
        return head;
    }
    head->pre = NULL;
    head->next = NULL;
    //没有对data赋值,不代表data没有数据
    return head;
}

(2)添加数据

1,头插法

复制代码
//头插法
DoubleLinkList headInsert(DoubleLinkList l,int k){
    //1.新结点
    Node *s = (Node*)malloc(sizeof(Node));
    //判断
    if(s == NULL)
    {
        printf("内存申请失败\n");
        return l;
    }
    //2.初始化新结点
    s->data = k;
    s->next = l->next;
    s->pre = l;
    //添加
    if(l->next != NULL)
    {
        l->next->pre = s;
    }
    l->next = s; 

    return l;
}

2,尾插法

复制代码
//尾插法
DoubleLinkList tailInsert(DoubleLinkList l,int k){
    //1.新结点
    Node *s = (Node*)malloc(sizeof(Node));
    //判断
    if(s == NULL)
    {
        printf("内存申请失败\n");
        return l;
    }
    //2.初始化新结点
    s->data = k;
    s->next = NULL;
    //查找并添加
    Node *temp = l;
    while(temp->next!=NULL)
    {
        temp = temp->next;
    }
    s->pre = temp;
    temp->next = s;

    return l;

}

3,中间插入

复制代码
//中间插入
DoubleLinkList middleInsert(DoubleLinkList l,int x,int k){
    //新结点
    Node *s = (Node*)malloc(sizeof(Node));
    s->data = k;

    Node*p = Find(l,x);
    if(p == NULL)
    {
        printf("查无此数据\n");
        return l;
    }
    s->next = p->next;
    if(p->next!=NULL)
    {
        p->next->pre = s;
    }
    p->next = s;
    s->pre = p;
    
    return l;

}

(3)查找

复制代码
//查找
Node *Find(DoubleLinkList l,int x){
    Node *temp = l->next;
    while(temp!=NULL&&temp->data!=x)
    {
        temp = temp->next;
    }
    return temp;
}

(4)删除

复制代码
//删除
DoubleLinkList delete(DoubleLinkList l,int x){
    Node *temp = Find(l,x);
    if(temp == NULL)
    {
        printf("查无此数据\n");
        return l;
    }
    temp->pre->next = temp->next;
    if(temp->next != NULL)
    {
        temp->next->pre = temp->pre;
    }
    free(temp);
    temp = NULL;
    return l;
}

(5)修改

复制代码
//修改
DoubleLinkList changeList(DoubleLinkList l,int x,int k){
    Node* temp = Find(l,x);
    if(temp == NULL)
    {
        printf("查无此数据\n");
        return l;
    }
    temp->data = k;
    return l;
}

(6)输出

复制代码
//输出
void printff(DoubleLinkList l){
    Node *temp = l->next;
    if(temp == NULL)
    {
        printf("空链表,数据为空\n");
    }
    while(temp!=NULL)
    {
        printf("%d ",temp->data);
        temp = temp->next;
    }
}
相关推荐
weixin_4577600016 小时前
Python 数据结构
数据结构·windows·python
明洞日记17 小时前
【数据结构手册002】动态数组vector - 连续内存的艺术与科学
开发语言·数据结构·c++
fashion 道格18 小时前
数据结构实战:深入理解队列的链式结构与实现
c语言·数据结构
xxxxxxllllllshi18 小时前
【LeetCode Hot100----14-贪心算法(01-05),包含多种方法,详细思路与代码,让你一篇文章看懂所有!】
java·数据结构·算法·leetcode·贪心算法
铁手飞鹰19 小时前
二叉树(C语言,手撕)
c语言·数据结构·算法·二叉树·深度优先·广度优先
[J] 一坚20 小时前
深入浅出理解冒泡、插入排序和归并、快速排序递归调用过程
c语言·数据结构·算法·排序算法
司铭鸿21 小时前
祖先关系的数学重构:从家谱到算法的思维跃迁
开发语言·数据结构·人工智能·算法·重构·c#·哈希算法
yk0820..21 小时前
测试用例的八大核心要素
数据结构
北京地铁1号线1 天前
数据结构:堆
java·数据结构·算法
得物技术1 天前
从数字到版面:得物数据产品里数字格式化的那些事
前端·数据结构·数据分析