C语言——链表(基础篇)

链表是一种非常重要的数据结构,在很多场景中都有广泛的应用,基本用法是动态存储链表的大小可以动态增长或缩小,不像数组那样需要预先分配固定的内存空间。这使得它在数据量不确定的情况下非常有用。相当于内存不连续的变长数组。

一个简单的 C 语言链表实现,包括链表节点的定义、创建节点、插入节点(头部插入和尾部插入)、删除节点和遍历链表的操作

本文为链表基础篇,链表基础入门,使用偏向c语言的代码,比c++代码冗长。

节点构建:

链表的基本单元是节点(node),每个节点包含一个值和指向下一个节点的指针。

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

这是一个数据类型为结构体指针的函数,使用new开辟新节点并进行初始化,返回新建节点的指针 

struct ListNode* createNode(int data) {
    struct ListNode* newNode=new ListNode();
    if(newNode==NULL){exit(-1);}//如果内存分配失败退出并返回-1
    newNode->data=data;
    newNode->next=NULL;
    return newNode;
}
链表的构建:

在头部(前面)添加节点: 

void insertAtHead(struct ListNode** head, int data) {
    struct ListNode* newNode=createNode(data);
    newNode->next=*head;//与原头部先连接
    *head=newNode;//更新头部
}

 在链表操作里,我们经常要对链表的头指

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值