数据结构-链表

1.链表

定义: 链表是一种物理存储上非连续,数据元素的逻辑顺序通过链表中的指针链接次序,实现的一种线性存储结构。

链表节点分为两个域

数据域:存放各种实际的数据,如:num、score等

指针域:存放下一节点的首地址,如:next等.

c 复制代码
struct Node{
	int data;			//数据域
	struct Node* next   //指针域
}

2.链表创建

  1. 创建链表(创建一个表头表示整个链表)

    c 复制代码
    //表头
    struct Node *createList()
    {
        struct Node *head = (struct Node*)malloc(sizeof (struct Node));
        //head成为了结构体变量
        head->next = NULL;
        return head;
    }
  2. 创建结点

    c 复制代码
    //创建结点
    struct Node* createNode(int data)
    {
        struct Node *node = (struct Node*)malloc(sizeof (struct Node));
        node->data = data;
        node->next = NULL;
        return node;
    }
  3. 插入结点

    c 复制代码
    //头部插入结点
    void insertNodeHead(struct Node *head, int data)
    {
        //创建插入的结点
        struct Node *new = createNode(data);
    
        new->next = head->next;
        head->next = new;
    }
  4. 删除结点

    c 复制代码
    //指定位置删除
    void deleteNode(struct Node *head, int index)
    {
        struct Node *pos = head->next;
        struct Node *posFront = head;
        if (pos == NULL)
            return;     //链表为空
        while(pos ->data != index)
        {
            posFront = pos;
            pos = pos->next;
            if (pos == NULL)  //表尾
                return;
        }
        posFront->next = pos->next;
        free(pos);
    }

    注意:链表的每一个结点都是动态开辟(malloc)出来的,删除结点后需要释放掉。

  5. 打印遍历链表

    c 复制代码
    void printList(struct Node *node)
    {
        struct Node *p = node->next;
        while(p->next != NULL)
        {
            printf("%d ", p->data);
            p = p->next;
        }
        printf("\n");
    }

3.测试代码

c 复制代码
#include "stdio.h"

struct  Node
{
    int data;
    struct Node *next;
};

struct Node *createList()
{
    struct Node *head = (struct Node*)malloc(sizeof (struct Node));
    //head成为了结构体变量
    head->next = NULL;
    return head;
}

struct Node* createNode(int data)
{
    struct Node *node = (struct Node*)malloc(sizeof (struct Node));
    node->data = data;
    node->next = NULL;
    return node;
}

void printList(struct Node *node)
{
    struct Node *p = node->next;
    while(p)
    {
        printf("%d ", p->data);
        p = p->next;
    }
    printf("\n");
}
//头部插入节点
void insertNodeHead(struct Node *head, int data)
{
    //创建插入的节点
    struct Node *new = createNode(data);

    new->next = head->next;
    head->next = new;
}

//指定位置删除
void deleteNode(struct Node *head, int index)
{
    struct Node *pos = head->next;
    struct Node *posFront = head;
    if (pos == NULL)
        return;     //链表为空
    while(pos ->data != index)
    {
        posFront = pos;
        pos = pos->next;
        if (pos == NULL)  //表尾
            return;
    }
    posFront->next = pos->next;
    free(pos);
}

int main()
{
    struct node *list = createList();
    insertNodeHead(list,1);
    insertNodeHead(list,2);
    insertNodeHead(list,3);
    insertNodeHead(list,4);
    printList(list);
    deleteNode(list,2);
    printList(list);
    //printf("Hello World!\n");
    return 0;
}

参考来源:

【1个小时学会单链表,C语言数据结构专题】https://www.bilibili.com/video/BV1Rb411F738?vd_source=3075951c704cf80b7df7522fbb58214d

链表基础知识详解(非常详细简单易懂)-CSDN博客

建议画图理解!!!

相关推荐
是苏浙1 小时前
初识集合框架
java·数据结构
如何原谅奋力过但无声2 小时前
【chap11-动态规划(上 - 基础题目&背包问题)】用Python3刷《代码随想录》
数据结构·python·算法·动态规划
小王C语言3 小时前
【基础IO】————简单设计一下libc库
前端·数据结构·算法
_日拱一卒3 小时前
LeetCode:滑动窗口的最大值
数据结构·算法·leetcode
老约家的可汗4 小时前
list 容器详解:基本介绍与常见使用
c语言·数据结构·c++·list
Book思议-4 小时前
【数据结构】字符串模式匹配:暴力算法与 KMP 算法实现与解析
数据结构·算法·kmp算法·bf算法
mifengxing4 小时前
力扣HOT100——(1)两数之和
java·数据结构·算法·leetcode·hot100
罗湖老棍子4 小时前
【 例 1】区间和(信息学奥赛一本通- P1547)(基础线段树和单点修改区间查询树状数组模版)
数据结构·算法·线段树·树状数组·单点修改 区间查询
Book思议-5 小时前
【数据结构】栈与队列核心对比
数据结构·栈与队列对比
旺仔.2915 小时前
常用算法 详解
数据结构·算法