C++链表相关内容温习回顾——移除链表元素

news2025/1/16 16:13:41

   本文主要对之前学过的C++链表相关内容进行温习回顾,并以 移除链表元素 为例,进行应用。

   关于链表的基础理论可见:链表理论基础

   应用示例:LeetCode 203 移除链表元素

   https://leetcode.cn/problems/remove-linked-list-elements/

在这里插入图片描述

   0、例题描述如下:

在这里插入图片描述

   1、带详细注释的可在本地IDE运行的C++链表实现如下:

#include<iostream>
#include<vector>

using namespace std;

// 定义链表的节点结构
struct ListNode
{
	int val;  // 节点存储的值
	ListNode* next;  // 指向下一个节点的指针
	ListNode() :val(0), next(nullptr) {}  // 默认构造函数
	ListNode(int x) :val(x), next(nullptr) {}  // 构造函数初始化值
	ListNode(int x, ListNode* ptr) :val(x), next(ptr) {}  // 构造函数初始化值和指针
};

// 定义解决问题的类
class Solution
{
public:
	// 移除链表中所有值为val的节点
	ListNode* removeElements(ListNode* head, int val)
	{  
		ListNode* vhead = new ListNode(0);  // 创建虚拟头节点以简化边界处理
		vhead->next = head;  // 将虚拟头节点指向实际的头节点
		ListNode* cur = vhead;  // 使用cur遍历链表
		while (cur->next != nullptr)  // 遍历链表直到尾部
		{
			if (cur->next->val == val)  // 如果当前节点的下一个节点的值等于val
			{
				ListNode* temp = cur->next;  // 临时保存需要删除的节点
				cur->next = cur->next->next;  // 将当前节点的指针指向下下个节点
				delete temp;  // 删除节点释放内存
			}
			else
			{
				cur = cur->next;  // 移动到下一个节点
			}
		}

		head = vhead->next;  // 更新头节点
		delete vhead;  // 删除虚拟头节点
		return head;  // 返回新的头节点
	}
};

int main()
{
	// 创建测试链表 [1,2,6,3,4,5,6]
	ListNode* head = new ListNode(1);
	head->next = new ListNode(2);
	head->next->next = new ListNode(6);
	head->next->next->next = new ListNode(3);
	head->next->next->next->next = new ListNode(4);
	head->next->next->next->next->next = new ListNode(5);
	head->next->next->next->next->next->next = new ListNode(6);

	Solution solution;
	int val = 6;
	head = solution.removeElements(head, val);  // 调用removeElements函数移除值为6的节点

	// 打印新的链表
	ListNode* cur = head;
	while (cur != nullptr)  // 遍历链表打印每个节点的值
	{
		cout << cur->val << " ";
		cur = cur->next;
	}
	cout << endl;

	// 释放链表内存
	cur = head;
	ListNode* next;
	while (cur != nullptr)
	{
		next = cur->next;  // 保存下一个节点
		delete cur;  // 删除当前节点
		cur = next;  // 移动到下一个节点
	}
}

   运行结果如下:

在这里插入图片描述

   2、程序的详细介绍

   这个程序实现了一个特定的链表操作,即删除链表中所有值等于给定整数 val 的节点。程序分为几个主要部分:

   1. ListNode 结构体:定义链表的节点,每个节点包含一个整数值 val 和一个指向下一个节点的指针 next

   2. Solution 类

   - removeElements 方法:这是类的主要方法,用于移除链表中所有值为 val 的节点。方法通过添加一个虚拟头节点来简化边界条件的处理,然后遍历链表,逐个检查每个节点的值。

   3. main 函数

   - 创建并初始化链表。

   - 调用 removeElements 方法处理链表。

   - 打印处理后的链表结果。

   - 释放链表中所有节点的内存,以防止内存泄漏。

   4. 函数语句的详情介绍见上面代码的注释

   这个程序特别适用于学习和理解链表的操作,特别是如何处理删除链表节点时的边界条件。通过使用虚拟头节点,代码更加简洁,逻辑更清晰。

   3、LeetCode 核心代码模式源码:

/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode() : val(0), next(nullptr) {}
 *     ListNode(int x) : val(x), next(nullptr) {}
 *     ListNode(int x, ListNode *next) : val(x), next(next) {}
 * };
 */
class Solution
{
public:
	ListNode* removeElements(ListNode* head, int val)
	{  
		ListNode* vhead = new ListNode(0);
		vhead->next = head;
		ListNode* cur = vhead;
		while (cur->next != nullptr)
		{
			if (cur->next->val == val)
			{
				ListNode* temp = cur->next;
				cur->next = cur->next->next;
				delete temp;
			}
			else
			{
				cur = cur->next;
			}
		}

		head = vhead->next;
		delete vhead;
		return head;
	
	}
};

   4、一种可能的ACM模式源码:

   由于未知具体的输入给定形式,本例子中以如下所示的输入格式为例

[1,2,6,3,4,5,6] 6

   示例程序如下:

#include<iostream>
#include<vector>

using namespace std;

struct ListNode {
    int val;
    ListNode* next;
    ListNode() : val(0), next(nullptr) {}
    ListNode(int x) : val(x), next(nullptr) {}
    ListNode(int x, ListNode* ptr) : val(x), next(ptr) {}
};

class Solution {
public:
    ListNode* removeElements(ListNode* head, int val) {
        ListNode* vhead = new ListNode(0);  // 创建虚拟头节点以简化边界处理
        vhead->next = head;
        ListNode* cur = vhead;
        while (cur->next != nullptr) {
            if (cur->next->val == val) {
                ListNode* temp = cur->next;
                cur->next = cur->next->next;
                delete temp;
            } else {
                cur = cur->next;
            }
        }
        head = vhead->next;
        delete vhead;
        return head;
    }
};

int main() {
    vector<int> nums;
    int num, val;
    char ch;
    
    // 读取链表数值,以及需要移除的数值
    while (cin >> ch && ch != ']') { // 读取直到遇到 ']'
        if (cin >> num) {
            nums.push_back(num);
            cin >> ch; // 读取逗号或者结束的 ']'
        }
    }

    cin >> val; // 读取需要移除的数值

    // 构建链表
    ListNode* head = nullptr, * tail = nullptr;
    for (int number : nums) {
        ListNode* newNode = new ListNode(number);
        if (!head) {
            head = tail = newNode;
        } else {
            tail->next = newNode;
            tail = newNode;
        }
    }

    Solution solution;
    head = solution.removeElements(head, val);

    // 输出新链表
    ListNode* cur = head;
    if (cur) {
        cout << cur->val;
        cur = cur->next;
    }
    while (cur) {
        cout << "," << cur->val;
        cur = cur->next;
    }
    cout << endl;

    // 释放链表内存
    cur = head;
    ListNode* next;
    while (cur) {
        next = cur->next;
        delete cur;
        cur = next;
    }
}

   参考输入的运行结果如下:

1,2,3,4,5

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1832945.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Redis作者长文总结LLMs, 能够取代99%的程序员

引言 这篇文章并不是对大型语言模型&#xff08;LLMs&#xff09;的全面回顾。很明显&#xff0c;2023年对人工智能而言是特别的一年&#xff0c;但再次强调这一点似乎毫无意义。相反&#xff0c;这篇文章旨在作为一个程序员个人的见证。自从ChatGPT问世&#xff0c;以及后来使…

定个小目标之刷LeetCode热题(22)

这道题最容易想的就是排序后再遍历&#xff0c;但是时间复杂度就不是O(n)了&#xff0c;所以还是得用更优的解法&#xff0c;直接看题解&#xff0c;它是使用了HashSet&#xff0c;遍历数组&#xff0c;对于每一个数x&#xff0c;如果不存在x - 1则进入内循环&#xff0c;否则跳…

springboot弘德图书馆座位预约管理系统-计算机毕业设计源码07028

摘 要 在面对当今培育人才计划的压力&#xff0c;人们需要汲取更多的不同领域的知识来不断扩充自己的知识层面&#xff0c;因此他们对学习的欲望不断扩大&#xff0c;图书馆作为我们的学习宝地&#xff0c;有着不可替代的地位。但是在信息化时代&#xff0c;传统模式下的图书馆…

四川蔚澜时代电子商务有限公司抖音开店靠谱吗?

在数字化浪潮席卷全球的今天&#xff0c;电子商务以其独特的魅力和优势&#xff0c;成为了推动经济发展的重要引擎。作为四川地区电商服务的佼佼者&#xff0c;四川蔚澜时代电子商务有限公司凭借其深厚的行业积淀和前瞻的战略眼光&#xff0c;专注于抖音电商服务领域&#xff0…

pytest并发执行时token异常处理问题

接前面加入钩子函数处理token复用的问题&#xff0c;只保证了用例的串联执行&#xff0c;我的部分测试用例中接入了通义千问的部分接口生成测试数据&#xff0c;七八个场景跑完差不多快要10分钟。考虑使用并发执行。 http://t.csdnimg.cn/ACexL 使用多线程和不使用耗时差距很大…

Node-red win11安装

文章目录 前言一、安装node.js和npm二、安装Node-red三、 运行Node-red 前言 Node-RED 是一种编程工具&#xff0c;用于以新颖有趣的方式将硬件设备、API 和在线服务连接在一起。 它提供了一个基于浏览器的编辑器&#xff0c;只需单击一下即可将调色板中的各种节点轻松连接在…

EXCEL数据导入HIVE

引言 本文将论述如何将Windows本地的excel表数据,导入到虚拟机Linux系统中的Hadoop生态中的Hive数据仓库中。 实验准备 DBeaver Hive3.1(Hadoop3.1) excel数据表 实验步骤 一、首先打开虚拟机,启动Hadoop,启动hive,启动hiveserver2,连接DBeaver,成功连接展示如下…

VS2022打开.netcore2.2 问题解决

1.vs2022运行时一直提示异常 2.解决方法&#xff0c;双击当前的项目修改xxxx.csproj文件 把当前的版本修改为2.2.0即可重新编译运行

便携式手持气象仪:低功耗设计

TH-LSZ05便携式手持气象仪是一款轻便、操作简便的气象监测工具&#xff0c;集成了风向、风速、大气压、温度、湿度五项气象要素的测量功能。这些设备通常设计为体积小、重量轻&#xff0c;以便于用户随时携带并使用。通过使用手持气象仪&#xff0c;用户可以实时获取关键的气象…

MYSQL 三、mysql基础知识 7(MySQL8其它新特性)

一、mysql8新特性概述 MySQL从5.7版本直接跳跃发布了8.0版本 &#xff0c;可见这是一个令人兴奋的里程碑版本。MySQL 8版本在功能上 做了显著的改进与增强&#xff0c;开发者对MySQL的源代码进行了重构&#xff0c;最突出的一点是多MySQL Optimizer优化器进行了改进。不仅在速度…

【QT5】<重点> QT网络编程

文章目录 前言 一、QT中的TCP编程 1. TCP简介 2. 服务端程序编写 3. 客户端程序编写 4. 服务端与客户端测试 二、QT中的UDP编程 1. UDP简介 2. UDP单播与广播程序 前言 本篇记录QT中TCP和UDP网络编程知识。 一、QT中的TCP编程 1. TCP简介 TCP是面向连接的、可靠的、…

关于事务流的思考

关于事务流的思考 1 事务流业务分析 ​ 不同业务可能有不同的审核流程&#xff0c;而activiti为大家提供了一套公用的审核功能&#xff0c;基于这些功能我们可以根据自己的业务需求组合出我们自己的审核流程&#xff0c;而这里我要实现的事务流有如下功能&#xff1a;角色为结…

MySQL 数据库 Navicat Premium 16.01 安装教程

MySQL 数据库 Navicat Premium 16.01 安装教程 目录 MySQL 数据库 Navicat Premium 16.01 安装教程前言安装步骤同意协议选择安装目录桌面快捷方式安装正在安装安装完成 步骤获取 前言 MySQL数据库管理用Navicat更加方便&#xff0c;可视化效果更好&#xff0c;今天给大家带来…

八股文之JVM

目录 1.JVM内存划分 2.JVM类加载过程 3.JVM垃圾回收机制GC 3.1.判断谁是垃圾 3.2.如何释放对应的内存 1.JVM内存划分 在一个Java程序运行起来之后&#xff0c;jvm就会从操作系统中申请一块内存&#xff0c;然后就会将该内存划分成多个部分&#xff0c;用于不同的用途。 …

python-03

使用File操作文件 open(file, moder, buffering-1,encodingNone, errorsNone, newlineNone, closefdTrue, openerNone) file&#xff1a;要打开的文件 mode&#xff1a;文件打开模式。默认访问模式是读&#xff08;r&#xff09; buffering&#xff1a;缓冲区大小 encodin…

淘宝商品评论API接口测试实例(获取淘宝商品评论,翻页展示、支持并发)

item_review-获得淘宝商品评论 测试页 公共参数 名称类型必须描述keyString是调用key&#xff08;必须以GET方式拼接在URL中&#xff09;secretString是调用密钥api_nameString是API接口名称&#xff08;包括在请求地址中&#xff09;[item_search,item_get,item_search_shop…

学生党蓝牙耳机性价比排行榜,好评榜TOP5机型推荐

随着科技的飞速发展&#xff0c;蓝牙耳机已经成为我们日常生活中不可或缺的一部分&#xff0c;无论是运动健身、通勤路上还是休闲娱乐&#xff0c;它都为我们带来了极大的便利&#xff0c;然而&#xff0c;市面上的蓝牙耳机种类繁多&#xff0c;价格参差不齐&#xff0c;如何选…

pg——psql命令行交互式客户端工具

1、启动数据库 ./pg_ctl -D /usr/local/pgsql/data/ -l /usr/local/pgsql/log 2、登录数据库 psql template1 3、查看所有数据库 \l 4、创建数据库 create database testdb; 5、连接某数据库 \c 数据库 6、查看数据下的表 \d 7、 查看数据库下的所有schema \dn 8、查看表的结构…

业务表对应主键为varChar类型且无自增策略的新增与修改问题

业务表对应主键为varChar类型且无自增策略的新增与修改问题 上周五领到一个需求&#xff0c;在开发过程中遇到一点小插曲&#xff0c;在此记录下&#xff0c;话不多说&#xff0c;直接看表结构&#xff1a; 这里机构id为主键且无自增策略&#xff0c;也就是说机构id这个字段是…

PHP安装配置

文章目录 1.下载PHP2.配置环境变量3.Apache安装配置 1.下载PHP PHP即“超文本预处理器”&#xff0c;是一种通用开源脚本语言。PHP是在服务器端执行的脚本语言&#xff0c;与C语言类似&#xff0c;是常用的网站编程语言。PHP独特的语法混合了C、Java、Perl以及 PHP 自创的语法…