当前位置: 首页 > news >正文

单向链表的建立

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

先明确:头结点不存有效数据,仅作为链表的 “入口”,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(头插),避免野指针。
http://www.cnnetsun.cn/news/170876.html

相关文章:

  • 《Python == 与 is 的真相:从基础语义到底层机制,一篇让新手顿悟、老手沉默的深度解析》
  • Excalidraw HTTPS加密传输:保障通信安全
  • Excalidraw容器化部署:Kubernetes集群完美适配
  • 7、脚本开发与使用全攻略
  • 14、ADSI数据访问与对象枚举全解析
  • 必须精通了hyperf才算学会了swoole吗?
  • Excalidraw与Figma对比:哪个更适合早期原型设计?
  • 02.03.01.快速开始篇(Astra-SDK案例 使用Eclise开发工具:创建Makefile项目方式 DepthReaderEventCPP)
  • Excalidraw二维码分享:移动端访问一键直达
  • 基于Springboot粮仓管理系统【附源码+文档】
  • 基于Springboot笔记本分享平台【附源码+文档】
  • 浩瀚宇宙,2025正是引力场文场的起点
  • Excalidraw热键大全:高手都是这样快速操作的
  • SQLite Unions 子句详解
  • 30、Windows Media Player使用指南
  • 高配云电脑推荐:2025横评,谁在延迟、价格、游戏库上全面胜出?
  • Excalidraw多端适配策略:手机也能流畅画图
  • 《从数据到转化:游戏地域偏好驱动的精准推送指南》
  • Excalidraw与Notion集成教程:打造智能知识库配图系统
  • 大模型技术与应用开发全流程详解:零基础入门到项目实战写给小白的大模型入门教程!
  • 10、Windows 10任务栏与系统托盘使用指南
  • Excalidraw使用指南:零基础学会AI驱动的图形自动生成
  • 24、Windows 10个性化设置全攻略
  • 32、Windows 10 照片管理与系统修复全攻略
  • 15、玩转 Windows:程序、文件操作与查找指南
  • 32、Windows 10 照片与系统修复实用指南
  • 从想法到图表只需一句话:Excalidraw集成AI绘图功能上线
  • 提升效率利器:Excalidraw集成AI绘图功能全揭秘
  • 开源Excalidraw怎么玩?AI赋能让流程图自动生成
  • 【IEEE 13 节点分配系统中的THD降低】系统的谐波分析给出了各种总线上电流和电压的谐波频谱和THD附Simulink仿真