news 2026/2/4 14:28:24

单向链表的建立

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
单向链表的建立

核心前提:带头结点链表的结构

先明确:头结点不存有效数据,仅作为链表的 “入口”,head->next指向第一个存储数据的结点。这是我们所有创建方法的基础,能避免空链表的特殊处理,新手优先掌握这种结构。


方法 1:尾插法

核心思路

  • 定义tail(尾指针),始终指向链表最后一个结点
  • 每新增一个结点,直接接在tail后面,然后更新tail到新结点;
  • 优点:插入效率高(不用每次找最后一个结点),链表中结点顺序和输入顺序一致。

适配学生信息链表的代码示例(完整可运行)

cpp

运行

#include<iostream> #include<string> using namespace std; struct student { string id; string nm; string cj; student* next; }; // 尾插法创建学生链表(封装成函数,更清晰) student* createListByTail() { // 1. 创建头结点 student *head = new student(); head->next = nullptr; student *tail = head; // 尾指针初始指向头结点 string a, b, c; while (true) { cin >> a >> b >> c; if (a == "0") break; // 输入0结束 // 2. 创建新结点并赋值 student *newNode = new student(); newNode->id = a; newNode->nm = b; newNode->cj = c; newNode->next = nullptr; // 3. 尾插核心:接在tail后面,更新tail tail->next = newNode; tail = newNode; } return head; } // 遍历输出链表 void printList(student* head) { student *p = head->next; while (p != nullptr) { cout << p->id << " " << p->nm << " " << p->cj << endl; p = p->next; } } int main() { student *head = createListByTail(); cout << "尾插法创建的链表:" << endl; printList(head); // 释放内存(省略,和之前一致) return 0; }

尾插法关键步骤(白话版)

  1. 造一个 “空盒子”(头结点),tail先 “抓着” 这个空盒子;
  2. 输入数据→造新盒子存数据→把tail抓着的盒子的 “尾巴”(next)连到新盒子;
  3. tail松开原来的盒子,改抓新盒子(下次新盒子就接在这);
  4. 重复直到输入 0,链表就建好了。

方法 2:头插法(逆序插入,适合需要反转顺序的场景)

核心思路

  • 不设尾指针,每新增一个结点,直接插在头结点和第一个有效结点之间
  • 优点:插入更简单(不用维护 tail);缺点:链表中结点顺序和输入顺序相反

适配学生信息链表的代码示例

cpp

运行

#include<iostream> #include<string> using namespace std; struct student { string id; string nm; string cj; student* next; }; // 头插法创建学生链表 student* createListByHead() { // 1. 创建头结点 student *head = new student(); head->next = nullptr; string a, b, c; while (true) { cin >> a >> b >> c; if (a == "0") break; // 2. 创建新结点并赋值 student *newNode = new student(); newNode->id = a; newNode->nm = b; newNode->cj = c; // 3. 头插核心:先连后面,再接头结点 newNode->next = head->next; // 新结点的next指向原来的第一个有效结点 head->next = newNode; // 头结点的next指向新结点(新结点成第一个) } return head; } // 遍历输出链表 void printList(student* head) { student *p = head->next; while (p != nullptr) { cout << p->id << " " << p->nm << " " << p->cj << endl; p = p->next; } } int main() { student *head = createListByHead(); cout << "头插法创建的链表(顺序反转):" << endl; printList(head); // 释放内存(省略) return 0; }

头插法关键步骤(白话版)

  1. 造一个 “空盒子”(头结点);
  2. 输入数据→造新盒子存数据;
  3. 新盒子先 “抓着” 原来第一个有数据的盒子;
  4. 头结点松开原来的第一个盒子,改抓新盒子(新盒子变成第一个);
  5. 重复直到输入 0,链表建好(输入顺序 101→102→103,输出会是 103→102→101)。

两种方法对比(新手必看)

方法核心指针结点顺序适用场景
尾插法tail和输入顺序一致大多数场景(如存储学生信息)
头插法无(只用 head)和输入顺序相反需要反转顺序、栈结构等场景

总结(核心要点)

  1. 带头结点链表创建的基础步骤:先创建头结点→循环输入数据→创建新结点赋值→插入链表→结束循环;
  2. 尾插法是新手优先掌握的方法,核心是维护tail指针,保证结点顺序和输入一致;
  3. 头插法不用维护tail,但会反转顺序,适合特定场景;
  4. 无论哪种方法,新结点的next必须设为nullptr(尾插)或head->next(头插),避免野指针。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/3 13:00:23

前端如何用 XinServer 轻松实现数据权限管控?

前端如何用 XinServer 轻松实现数据权限管控&#xff1f; 最近跟几个做前端的朋友聊天&#xff0c;发现大家普遍有个头疼的问题&#xff1a;项目做到一半&#xff0c;产品经理突然说&#xff0c;“这个页面&#xff0c;A部门的员工只能看到自己的数据&#xff0c;B部门的领导要…

作者头像 李华
网站建设 2026/2/3 13:38:08

Excalidraw移动端使用体验报告

Excalidraw移动端使用体验深度解析 在远程办公成为常态的今天&#xff0c;团队协作早已不再局限于文档和会议通话。越来越多的技术讨论、产品构思甚至系统设计&#xff0c;都发生在一块“虚拟白板”上。而在这类工具中&#xff0c;Excalidraw 凭借其独特的手绘风格与极简交互&…

作者头像 李华
网站建设 2026/2/3 5:13:49

Excalidraw访问者模式扩展:数据结构新增操作

Excalidraw访问者模式扩展&#xff1a;数据结构新增操作 在现代协作式设计工具中&#xff0c;团队对白板类应用的需求早已超越了“画个框连条线”的初级阶段。从系统架构图到产品原型草图&#xff0c;再到AI驱动的智能流程生成&#xff0c;Excalidraw 作为一款开源的手绘风格虚…

作者头像 李华
网站建设 2026/2/3 13:16:30

Excalidraw缩放平移算法:亿级画布仍保持流畅

Excalidraw缩放平移算法&#xff1a;亿级画布仍保持流畅 在现代前端图形应用中&#xff0c;用户早已不满足于“能画”——他们希望在一个无限延展的虚拟空间里自由创作&#xff0c;像在真实白板上那样拖动、放大、圈注&#xff0c;而系统依然响应如初。然而&#xff0c;当画布…

作者头像 李华
网站建设 2026/2/3 9:33:43

Excalidraw状态模式切换:对象行为动态变化

Excalidraw中的动态交互与智能协作&#xff1a;从状态切换到手绘渲染的工程实践 在远程协作日益成为常态的今天&#xff0c;团队沟通不再局限于文字和会议——可视化表达正迅速崛起为产品设计、系统架构和技术对齐的核心语言。而在这股趋势中&#xff0c;Excalidraw 以其极简的…

作者头像 李华
网站建设 2026/2/3 5:02:00

计算机网络-- TCP

目录 1.TCP的流量控制 2. TCP的拥塞控制 1.TCP的流量控制 一般来说,我们总是希望数据传输得更快一些。 但如果发送方把数据发送得过快,接收方就可能来不及接收,这就会造成数据的丢失。 所谓流量控制(flow control)就是让发送方的发送速率不要太快,要让接收方来得及接收。…

作者头像 李华