C语言单链表头插法

文章目录

一.单链表

  1. 什么是单链表?
    想象一串珍珠项链,每颗珍珠(节点)包含:
    数据域:存放具体数据(如数字、字符串)
    指针域:一根「看不见的线」指向下一颗珍珠

二.头插法

通俗理解单链表的「头插法」:像给火车加车厢一样简单

链表是数据结构中的「珍珠项链」,而头插法就是其中最常用的「穿珠手法」。用生活中的例子来理解:头插法就像在火车最前面加车厢,每次新节点都成为新的车头。 接下来用最直观的方式,手把手教你掌握这个核心操作。

三.具体实现过程

3.1用C语言的结构体表示:

c 复制代码
// 定义链表节点结构体
typedef struct {
    ElemType data;
    struct Node* next;
} Node;

3.2 头指针的作用

类似「项链的扣头」,永远指向链表的第一个节点

链表为空时,头指针指向NULL

3.3步骤2:将新节点插入链表头部 关键操作:

让新节点的next指向原头节点

更新头指针指向新节点

c 复制代码
    p->next = node->next;
    node->next = p;

模拟过程演示:

操作 图示

初始空链表 head → NULL

插入6 head → [6 NULL]

插入16 head → [16 →] → [6 NULL]

插入26 head → [26 →] → [16 →] → [6 NULL]

发现什么没?->先插入的数据反而在最后面去了.

全部代码

c 复制代码
//
// Created by xiaoyuan on 2025-03-08.
//


#include "stdio.h"
#include "stdlib.h"
#define MAXSIZE 100
typedef int ElemType;

// 定义链表节点结构体
typedef struct {
    ElemType data;
    struct Node* next;
} Node;

Node *initList(){
    Node *head =(Node *) malloc(sizeof(Node));
    head->data = 0;
    head->next =NULL;
    return head;
}





void insertHead(Node *node,ElemType value){
    Node *p = (Node *) malloc(sizeof(Node));
    p->data = value;
    p->next = node->next;
    node->next = p;
    printf("插入数据成功\n");
}



void showList(Node *node){
    Node  *p = node->next;  //如果这里直接用Node就会打印0
    for(int i=0;p != NULL;i++){
        printf(" %d -> ",p->data);
        p = p->next;
    }

}

int main(){

    //1.初始化链表
    Node *node = initList();

    //2.头插法
    insertHead(node,6);
    insertHead(node,16);
    insertHead(node,26);
    showList(node);
}
相关推荐
人生在勤,不索何获-白大侠3 分钟前
day16——Java集合进阶(Collection、List、Set)
java·开发语言
LIN-JUN-WEI21 分钟前
[ESP32]VSCODE+ESP-IDF环境搭建及blink例程尝试(win10 win11均配置成功)
c语言·开发语言·ide·vscode·单片机·学习·编辑器
望获linux1 小时前
【Linux基础知识系列】第四十三篇 - 基础正则表达式与 grep/sed
linux·运维·服务器·开发语言·前端·操作系统·嵌入式软件
留不住丨晚霞2 小时前
说说SpringBoot常用的注解?
java·开发语言
hardStudy_h2 小时前
C++——内联函数与Lambda表达式
开发语言·jvm·c++
艾莉丝努力练剑2 小时前
【C语言】学习过程教训与经验杂谈:思想准备、知识回顾(三)
c语言·开发语言·数据结构·学习·算法
黑听人3 小时前
【力扣 困难 C】115. 不同的子序列
c语言·leetcode
witton4 小时前
Go语言网络游戏服务器模块化编程
服务器·开发语言·游戏·golang·origin·模块化·耦合
枯萎穿心攻击4 小时前
ECS由浅入深第三节:进阶?System 的行为与复杂交互模式
开发语言·unity·c#·游戏引擎
Jerry Lau4 小时前
go go go 出发咯 - go web开发入门系列(一) helloworld
开发语言·前端·golang