C语言0基础的前端考研日记:头插法/尾插法创建单链表

一、头插法思路:

1、新节点的下一个节点指向链表的第一个节点

2、将头结点的下一个节点指向新节点

将数据按这个步骤处理后,新节点就会变为链表的第一个节点

前置知识点

malloc 函数 :用于从堆中分配一块指定大小的内存。

内存分配成功返回指向该内存块的指针,否则返回 NULL
使用方法 :('数据类型的指针')malloc('内存大小');
sizeof(Node) 获取Node类型所需内存大小

c 复制代码
#include <stdio.h>
#include <stdlib.h>

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

void insert (Node *L) {
 int x;
 scanf("%d", &x); // 让用户输入数据
 printf("插入%d\n", x); // 控制台打印用户输入的数据
 if (x != 0) { // 当x=0时,插入结束
   Node *n = (Node *)malloc(sizeof(Node)); // 
   printf ("data: %d next: %p\n", n->data, n->next);
   printf ("data: %d next: %p\n", L->data, L->next);
   if (n == NULL) {
     printf("内存分配失败\n");
     exit(0);
   }
   // 将用户输入的数据赋值给新节点
   n->data = x; // L: Head -> FirstNode -> NULL; n: n -> NULL;
   // 让节点n指向节点FirstNode
   n->next = L->next; // L: Head -> FirstNode -> NULL; n: n -> FirstNode -> NULL;
   // 将头结点的next指向新节点
   L->next = n;  // L: Head -> n -> FirstNode -> NULL
   insert(L); // 递归,直到用户输入的数据为0
 };
};
// 打印整个链表
void printList(Node *L) {
   Node *current = L->next; // 从头结点的下一个开始遍历
   while (current != NULL) {
       printf("%d -> ", current->data);
       current = current->next;
   }
   printf("NULL\n"); // 结束标志
}

int main() {
 Node L = {0, NULL};
 insert(&L);
 printList(&L);
 return 0;
}

二、尾插法思路

1、声明变量tail用于存储尾结点的指针,这样可以随时找到链表的尾结点

2、将尾结点的next指向新节点,此时新节点就会成为链表的尾结点

3、将新节点的指针赋值给tail

4、重复以上步骤,直到用户输入的数据为0, 结束链表的创建

相对于头插法只在insert、main做了修改

c 复制代码
void insert (Node *L, Node *last) {
  int x;
  scanf("%d", &x); // 让用户输入数据
  printf("插入%d\n", x); // 控制台打印用户输入的数据
  if (x != 0) { // 当x=0时,插入结束
    Node *n = (Node *)malloc(sizeof(Node));
    // 将用户输入的数据赋值给新节点
    n->data = x; // L: Head -> ... -> lastNode -> NULL; n: n -> NULL;
    // lastNode的next指向新节点
    last->next = n; // L: Head -> ... -> lastNode -> n -> NULL; last: *lastNode;
    // 新节点成为了链表尾结点
    last = n; // last: n;
    insert(L, last); // 递归,直到用户输入的数据为0
  } else {
    last->next = NULL; // 输入结束时将尾结点的next赋值为NULL
  };
};

int main() {
  Node L = {0, NULL};
  Node *lastPoint = &L;
  insert(&L, lastPoint);
  printList(&L);
  return 0;
}
相关推荐
酉鬼女又兒2 小时前
零基础入门计算机网络运输层:端到端通信核心作用、端口号分类规则、复用分用工作机制及UDP与TCP协议全方位对比详解
网络·网络协议·tcp/ip·计算机网络·考研·udp·php
m0_547486662 小时前
《C#语言程序设计与实践》 全套PPT课件
c语言·c#·c语言程序设计
牛油果子哥q2 小时前
并查集(DSU)超精讲,路径压缩、按秩合并、万能模板、连通性判定、最小生成树与刷题实战全解
数据结构·c++·最小生成树·并查集
✎ ﹏梦醒͜ღ҉繁华落℘2 小时前
编程基础 --高内聚,低耦合
c语言·单片机
凌波粒3 小时前
LeetCode--491.递增子序列(回溯算法)
数据结构·算法·leetcode
QK_004 小时前
C语言 static 关键字三大作用
c语言·开发语言
隔窗听雨眠4 小时前
C语言函数递归从入门到精通(下):性能优化与工程实践
c语言·算法·性能优化
WL学习笔记4 小时前
单项不带头不循环链表
数据结构·链表
小糯米6014 小时前
JS 数组
数据结构·算法·排序算法
小欣加油5 小时前
leetcode3612 用特殊操作处理字符串I
数据结构·c++·算法·leetcode·职场和发展