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

【C++】链表

链表是一种常见的数据结构,用于存储和组织数据。它的每个元素被称为结点(Node),结点是链表的基本单位,链表由一系列结点(Node)组成,每个结点包含两个部分:数据部分(数据域)和指针部分(指针域)。

数据域用于存储结点所携带的数据,可以是任意类型,例如整数、字符、对象等。而指针域用于存储指向下一个结点的指针,形成了结点之间的链接。因此链表的对象也被称为结点。每个结点代表链表中的一个元素或数据项。

链表有多种类型,其中最常见的是单向链表(Singly Linked List)和双向链表(Doubly Linked List)。

单向链表中,每个结点只有一个指针,指向下一个结点。链表的第一个结点称为头结点,最后一个结点的指针为空(NULL)。

双向链表中,每个结点有两个指针,一个指向前一个结点,一个指向下一个结点。这样的设计使得在双向链表中可以从任意一个结点开始,向前或向后遍历链表。

链表的优点之一是它的动态性。与数组不同,链表的大小可以在运行时动态地增长或缩小,不需要预先指定固定的容量。这使得链表在需要频繁插入和删除节点的场景中更加高效。

链表的缺点是访问特定位置的结点需要从头结点开始遍历,直到找到目标结点,因此访问效率较低。此外,链表需要额外的空间来存储结点的指针,因此在空间利用方面可能不如数组。

在实际应用中,链表常用于实现栈、队列和其他高级数据结构,也可以用作辅助数据结构来解决特定问题。

下面是一个简单的单向链表的示例代码,用于演示链表的基本操作:

#include <iostream>// 定义链表节点
struct Node {int data;Node* next;//data用于存储节点的数据,而next是指针域,用于指向下一个节点的地址。
};// 遍历并打印链表
void printLinkedList(Node* head) {Node* current = head;while (current != nullptr) {std::cout << current->data << " ";current = current->next;}std::cout << std::endl;
}int main() {// 创建链表节点Node* head = new Node();Node* second = new Node();Node* third = new Node();// 设置节点的数据和链接关系head->data = 1;head->next = second;second->data = 2;second->next = third;third->data = 3;third->next = nullptr;// 打印链表printLinkedList(head);// 释放链表内存delete head;delete second;delete third;return 0;
}

打印节点的数据,演示了链表的基本操作。

输出结果为:

1 2 3

这个例子展示了链表的创建、节点间的链接关系以及遍历打印的过程。可以根据具体需求对链表进行插入、删除等操作,实现更复杂的功能。

需要注意的是,在实际应用中,要特别注意链表的内存管理,包括节点的创建和释放。在释放链表时,需要逐个删除节点并释放其内存,避免内存泄漏。

另外,链表还可以有其他变种形式,例如循环链表(Circular Linked List)和带有头节点(Dummy Node)的链表等。这些变种形式根据具体需求和场景进行设计和应用。

总结起来,链表是一种常见的动态数据结构,适用于需要频繁插入和删除节点的场景。它的灵活性和动态性使其成为解决许多问题的有力工具。

相关文章:

【C++】链表

链表是一种常见的数据结构&#xff0c;用于存储和组织数据。它的每个元素被称为结点&#xff08;Node&#xff09;&#xff0c;结点是链表的基本单位&#xff0c;链表由一系列结点&#xff08;Node&#xff09;组成&#xff0c;每个结点包含两个部分&#xff1a;数据部分&#…...

day42_jsp

今日内容 零、 复习昨日 一、JSP 二、EL 三、JSTL 四、MVC 零、 复习昨日 一、JSP 1.0 引言 现有问题 在之前学习Servlet时&#xff0c;服务端通过Servlet响应客户端页面&#xff0c;有什么不足之处&#xff1f; 开发方式麻烦&#xff1a;继承父类、覆盖方法、配置Web.xml或注…...

JAVA面试八股整理——基础部分

JAVA 基础 JVM JDK JRE JVM java虚拟机&#xff0c;针对不同的系统&#xff0c;使用相同的字节码会给出相同结果。一次编译&#xff0c;随处可运行 JDK Java SDK 提供给开发者使用&#xff0c;创建和编译Java程序。包含了JRE&#xff0c;同时包含了其它工具&#xff08;jav…...

【JavaSE】Java基础语法(二十八):HashSet集合

文章目录 1. HashSet集合概述和特点2. HashSet集合的基本应用3. 哈希值4. HashSet集合存储学生对象并遍历【应用】 1. HashSet集合概述和特点 底层数据结构是哈希表存取无序不可以存储重复元素没有索引,不能使用普通for循环遍历 2. HashSet集合的基本应用 存储字符串并遍历 …...

压缩感知重构之匹配追踪算法

算法的重构是压缩感知中重要的一步&#xff0c;是压缩感知的关键之处。因为重构算法关系着信号能否精确重建&#xff0c;国内外的研究学者致力于压缩感知的信号重建&#xff0c;并且取得了很大的进展&#xff0c;提出了很多的重构算法&#xff0c;每种算法都各有自己的优缺点&a…...

【SpinalHDL快速入门】4.6、复合类型之Vec

文章目录 1.1、描述1.2、声明1.2.1、实例 1.3、运算符1.3.1、比较&#xff08;Comparison&#xff09;1.3.2、类型转换&#xff08;Type cast&#xff09;1.3.3、杂项&#xff08;Misc&#xff09;1.3.4、Lib辅助函数&#xff08;Lib helper functions&#xff09; 1.1、描述 …...

探访世优科技数字人虚拟直播产品体系 | 世优开放日再次成功举行

2023年5月30日&#xff0c;世优科技全栈技术产品体验活动&#xff08;第二期&#xff09;顺利落下帷幕。此次活动共邀请到30余位各行各业的嘉宾到场&#xff0c;在两个多小时的开放日活动中&#xff0c;世优科技全面展示数字人及虚拟直播领域的技术产品体系。来访嘉宾们全程体验…...

有奖励!2023陕西省首台(套)重大技术装备产品项目申报条件、认定材料

本文整理了2023陕西省首台&#xff08;套&#xff09;重大技术装备产品项目申报条件&#xff0c;认定材料等相关内容&#xff0c;感兴趣的朋友快跟小编一起来看看吧&#xff01; 一、重点支持方向及领域 重点支持方向及领域&#xff1a;高档工业母机、电力装备、大型矿山和冶金…...

2023/6/6总结

CSS 如果想要实现背景颜色渐变效果&#xff1a; left是从左边开始&#xff0c;如果想要对角线比如&#xff0c;左上角就是left top&#xff0c;渐变效果始终是沿着一条线来实现的。 下面是跟着视频教学用flex布局写的一个移动端网页&#xff1a; html代码&#xff1a; <!…...

api习题

// 1 整数或者小数 // String a"378.000"; // String rex"[1-9]\\d*|[0-9]|*\\.[0-9]*"; // System.out.println(a.matches(rex)); // 2 只能输入数字&#xff1a; // String rex"\\b*"; // 3 只能输入n位的数字&#xff1a; // String r…...

(STL之string)string类的用法详解

string类成员函数PART1 成员函数(构造函数拷贝构造函数)&#xff1a;string 函数原型&#xff1a; string(); string (const string& str); string (const string& str, size_t pos, size_t len npos); string (const char* s); string (const char* s, size_t n)…...

基于RT-Thread快速上手SD NAND 虚拟文件系统

SD NAND 也称之为贴片式TF卡&#xff0c;贴片式SD卡&#xff0c;采用标准的SDIO接口&#xff0c;兼容SPI接口。下图所示为CS 新一代CS SD NAND NP1GCR01-AOW 大小为128M&#xff0c;对比128M的SD卡&#xff0c;可以看到贴片SD卡尺寸更小&#xff0c;不要SD卡座&#xff0c;占…...

性能测试实战

目录 一、创建线程组与http(s)请求1、JMeter关键词2、创建线程组3、线程组参数举例说明案例1:模拟5个用户,同时访问百度案例2:模拟5个用户,同时访问百度,并且循环2次案例3:模拟5个线程,持续执行10秒的时间案例4:模拟10秒启动10个线程,循环执行20秒4、创建http请求a、操…...

【PWN · 总结】system返回shell(‘/bin/sh‘、‘sh‘、$(0))

pwn题中要通过system/excute等返回shell&#xff0c;进而cat flag。今天遇到一题&#xff0c;参数$(0)也可返回&#xff0c;有必要记录一下。 目录 前言 一、/bin/sh 1.strings 2.IDA 3.pwntools 4.ROPgadget 5.libc中寻找 二、sh 三、$(0) exp IDA查看机器码 …...

《庄子》笔记

庄子 前述&#xff1a;庄子&#xff0c;战国时宋国人。 1.鲲鹏&#xff1a;胸襟宽广&#xff0c;高远&#xff0c;无界限。 2.寒蝉和灵龟&#xff1a;小年的悲哀。 3.小麻雀的得意&#xff1a;境界不同&#xff0c;又有什么可比性呢。 4.列子随风而行&#xff1a;得大道者&…...

五、VBO、EBO 和 VAO

五、VBO、EBO 和 VAO VBO、EBO 和 VAO&#xff1a; VBO&#xff08;Vertex Buffer Object&#xff09;是指顶点缓冲区对象&#xff0c;而 EBO&#xff08;Element Buffer Object&#xff09;是指图元索引缓冲区对象&#xff0c;VAO 是顶点数据的缓冲区对象&#xff0c;VAO 和…...

数据库期末复习(7.2)查询优化

查询优化的概述 商用数据库花了很多的资金投入到查询优化。 查询优化的分类 逻辑查询优化 物理查询优化 比逻辑查询计划多了怎么去执行的方式,为的是数据操作速度更快 逻辑查询优化的三种关键技术 在科学研究的道路上我们往往不是一帆风顺的,人的认识也是局限的,但是我…...

深入探索:在std::thread中创建并管理QEventLoop的全面指南

深入探索&#xff1a;在std::thread中创建并管理QEventLoop的全面指南 1. 前言&#xff1a;理解QEventLoop和std::thread的基本概念1.1 QEventLoop的基本概念和工作原理1.2 std::thread的基本概念和工作原理1.3 QTimer的基本概念和工作原理 2. 在std::thread中创建QEventLoop&a…...

【Netty】Netty中的超时处理与心跳机制(十九)

文章目录 前言一、超时监测二、IdleStateHandler类三、ReadTimeoutHandler类四、WriteTimeoutHandler类五、实现心跳机制5.1. 定义心跳处理器5.2. 定义 ChannelInitializer5.3. 编写服务器5.4. 测试 结语 前言 回顾Netty系列文章&#xff1a; Netty 概述&#xff08;一&#…...

尚硅谷大数据hadoop教程_mapReduce

p67 课程介绍 p68概述 p69 mapreduce核心思想 p70 wordcount源码 序列化类型 mapReduce三类进程 p71 编程规范 用户编写的程序分成三个部分&#xff1a;Mapper、Reducer和Driver。 P72 wordcount需求案例分析 p 73 -78 案例环境准备 &#xff08;1&#xff09;创建maven…...

SAM 3图文对话式分割:‘红色书包’‘戴眼镜的人’等自然语言识别案例

SAM 3图文对话式分割&#xff1a;‘红色书包’‘戴眼镜的人’等自然语言识别案例 1. 引言&#xff1a;让AI看懂你的图片 你有没有遇到过这样的情况&#xff1f;看到一张照片&#xff0c;想找出里面某个特定的人或物体&#xff0c;但手动圈选太麻烦&#xff0c;特别是当图片中…...

OpenClaw数据可视化:GLM-4.7-Flash分析结果自动图表生成

OpenClaw数据可视化&#xff1a;GLM-4.7-Flash分析结果自动图表生成 1. 为什么需要自动化数据可视化 作为一名经常需要处理数据的开发者&#xff0c;我发现自己80%的时间都花在了数据清洗和图表调整上。每次分析新数据集时&#xff0c;都要重复这些步骤&#xff1a;写Python脚…...

嵌入式按键事件处理框架:高可靠消抖与复合操作状态机

1. Button库深度解析&#xff1a;面向嵌入式系统的高可靠性按键事件处理框架1.1 设计定位与工程价值Button库并非简单的GPIO电平读取封装&#xff0c;而是一个面向工业级嵌入式应用的状态感知型按键事件引擎。其核心设计目标是解决传统按键处理中长期存在的三大工程痛点&#x…...

如何高效获取网页媒体资源:猫抓插件的全方位技术指南

如何高效获取网页媒体资源&#xff1a;猫抓插件的全方位技术指南 【免费下载链接】cat-catch 猫抓 chrome资源嗅探扩展 项目地址: https://gitcode.com/GitHub_Trending/ca/cat-catch 在数字内容爆炸的时代&#xff0c;我们每天都会遇到想要保存的视频、音频和图片资源。…...

Fast-LIO2 + Lidar_IMU_Init:提升机器人定位精度的完整数据流与标定实战

Fast-LIO2与Lidar_IMU_Init融合实践&#xff1a;从标定到部署的机器人定位优化全流程 在机器人自主导航领域&#xff0c;激光雷达与IMU的融合定位系统已成为工业级应用的主流选择。然而&#xff0c;许多开发者在实际部署时会发现&#xff1a;即使采用了Fast-LIO2这样先进的激光…...

EfficientNet实战:如何在移动端部署B0-B7模型(附显存优化技巧)

EfficientNet移动端部署实战&#xff1a;从模型选型到显存优化全解析 在移动端和边缘计算场景中部署深度学习模型&#xff0c;就像给一辆跑车装上节能引擎——既要保持性能&#xff0c;又要极致压缩资源消耗。EfficientNet系列模型正是这种平衡艺术的代表作&#xff0c;但当开发…...

【实战指南】系统变量编辑权限问题全解析

1. 系统变量编辑权限问题解析 最近在帮同事调试开发环境时&#xff0c;遇到一个典型问题&#xff1a;明明已经用管理员账号登录&#xff0c;却死活改不了系统环境变量。这让我想起自己刚接触Windows系统时踩过的坑&#xff0c;今天就把这些经验系统梳理一下。 系统变量本质上是…...

千问3.5-27B效果展示:手写笔记图片→文字转录→知识点归类→复习卡片生成

千问3.5-27B效果展示&#xff1a;手写笔记图片→文字转录→知识点归类→复习卡片生成 1. 模型核心能力概览 Qwen3.5-27B作为一款视觉多模态理解模型&#xff0c;在知识处理领域展现出独特优势。它不仅能理解图片内容&#xff0c;还能对信息进行深度加工。本次重点展示其从手写…...

Phi-3 Forest Lab企业应用:金融研报关键数据提取+趋势归纳AI助理

Phi-3 Forest Lab企业应用&#xff1a;金融研报关键数据提取趋势归纳AI助理 1. 金融研报处理的行业痛点 金融分析师每天需要处理大量研报&#xff0c;从中提取关键数据并归纳趋势。传统人工处理方式面临三大挑战&#xff1a; 效率瓶颈&#xff1a;阅读一份20页的研报平均耗时…...

通道注意力与空间注意力【实战篇】

1. 通道注意力实战技巧 第一次在项目中引入通道注意力机制时&#xff0c;我对着论文反复调试了三天才跑通。现在回头看&#xff0c;其实核心代码不到20行&#xff0c;但当时确实踩了不少坑。通道注意力最实用的价值在于&#xff1a;它能自动发现哪些特征通道对当前任务更重要。…...