c语言 链表学习笔记

1:基础知识点

a:链表是由一系列独立的节点串联组成的线性数据结构,每个节点固定包含两个核心域:数据域与指针域。

数据域:专门用来存放节点要存储的实际数据

指针域:一个和节点同类型的指针变量,专门存放下一个节点的内存地址

在内存中是非连续存储的。和数组完全不同,数组的所有元素在内存中是一块连续、相邻的地址空间;而链表的每个节点可以分散在内存的不同位置,节点之间没有地址上的相邻要求,全靠指针域的地址来维系关联。

b:链表在指定位置插入、删除元素,不需要移动其他元素,仅需修改对应节点的指针指向即可。如果在数组中间插入 / 删除元素,需要移动插入位置之后的所有元素,数据量越大效率越低。

c:链表随机查找,访问速度远低于数组

d:没头结点的链表:头指针直接指向第一个存数据的节点。

复制代码
头指针 -> 第1个数据节点 -> 第2个数据节点 -> ... -> NULL

当你插入新节点时,由于它是新的"第一名",你必须强制修改头指针的指向,否则你找不到新的链表开头。

第一步:新节点的 next 指向当前的第一个节点。

第二步:头指针指向新节点。

有头结点链表:头指针指向头结点。

复制代码
头指针 -> 头结点 -> 第1个数据节点 -> 第2个数据节点 -> ... -> NULL

这是最推荐的做法。此时,头指针永远指向那个不动的"头结点"。在第一个位置插入,其实就是在头结点后面加塞

插入数据10演示:

具体例子:静态链表

cs 复制代码
#include <iostream>
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
struct linknode
{
    int data;
    struct linknode* next;
};
void test()
{
//创建结构体
    struct linknode node1 = { 10,NULL };
    struct linknode node2 = { 20,NULL };
    struct linknode node3 = { 30,NULL };
    struct linknode node4 = { 40,NULL };
    struct linknode node5 = { 50,NULL };
//链表连接
    node1.next = &node2;
    node2.next = &node3;
    node3.next = &node4;
    node4.next = &node5;
    node5.next = NULL;

    struct linknode* pcurrent = &node1;
    while (pcurrent != NULL)
    {
        printf("%d\n", pcurrent->data);
        pcurrent = pcurrent->next;
    }
}
int main()
{
    test();
    std::cout << "Hello World!\n";
}
相关推荐
列星随旋3 小时前
线段树和树状数组的学习
学习·算法
辰海Coding4 小时前
MiniSpring框架学习-整合 IoC 和 MVC(NPC)
学习·spring·mvc
ytttr8735 小时前
OPC UA 协议栈 C 语言实现
c语言·开发语言·mfc
song5015 小时前
Ascend C 算子开发:从入门到上手
c语言·开发语言·图像处理·人工智能·分布式·flutter·交互
小a杰.5 小时前
Ascend C编程语言进阶:高性能算子开发技巧
android·c语言·开发语言
知识分享小能手6 小时前
Flask入门学习教程,从入门到精通,数据库操作 — 知识点详解与案例代码(4)
数据库·学习·flask
小a杰.7 小时前
Ascend C算子开发实战 - 从零开始写算子
c语言·开发语言
wubba lubba dub dub7507 小时前
第四十八周学习周报
学习
生成论实验室7 小时前
用事件关系网络重新理解AI(三):激活函数、微调与元学习
人工智能·学习·算法·语言模型·可信计算技术
辰海Coding8 小时前
MiniSpring框架学习-为什么一个请求访问 /helloworld,最后能调用到某个 Controller 方法?原始 MVC实现
java·学习·程序人生·spring·mvc