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

2024-06-17 23:52

本文主要是介绍C++链表相关内容温习回顾——移除链表元素,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

   本文主要对之前学过的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

在这里插入图片描述

这篇关于C++链表相关内容温习回顾——移除链表元素的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1070740

相关文章

C++使用栈实现括号匹配的代码详解

《C++使用栈实现括号匹配的代码详解》在编程中,括号匹配是一个常见问题,尤其是在处理数学表达式、编译器解析等任务时,栈是一种非常适合处理此类问题的数据结构,能够精确地管理括号的匹配问题,本文将通过C+... 目录引言问题描述代码讲解代码解析栈的状态表示测试总结引言在编程中,括号匹配是一个常见问题,尤其是在

使用C++实现链表元素的反转

《使用C++实现链表元素的反转》反转链表是链表操作中一个经典的问题,也是面试中常见的考题,本文将从思路到实现一步步地讲解如何实现链表的反转,帮助初学者理解这一操作,我们将使用C++代码演示具体实现,同... 目录问题定义思路分析代码实现带头节点的链表代码讲解其他实现方式时间和空间复杂度分析总结问题定义给定

C++初始化数组的几种常见方法(简单易懂)

《C++初始化数组的几种常见方法(简单易懂)》本文介绍了C++中数组的初始化方法,包括一维数组和二维数组的初始化,以及用new动态初始化数组,在C++11及以上版本中,还提供了使用std::array... 目录1、初始化一维数组1.1、使用列表初始化(推荐方式)1.2、初始化部分列表1.3、使用std::

C++ Primer 多维数组的使用

《C++Primer多维数组的使用》本文主要介绍了多维数组在C++语言中的定义、初始化、下标引用以及使用范围for语句处理多维数组的方法,具有一定的参考价值,感兴趣的可以了解一下... 目录多维数组多维数组的初始化多维数组的下标引用使用范围for语句处理多维数组指针和多维数组多维数组严格来说,C++语言没

如何解决Pycharm编辑内容时有光标的问题

《如何解决Pycharm编辑内容时有光标的问题》文章介绍了如何在PyCharm中配置VimEmulator插件,包括检查插件是否已安装、下载插件以及安装IdeaVim插件的步骤... 目录Pycharm编辑内容时有光标1.如果Vim Emulator前面有对勾2.www.chinasem.cn如果tools工

CSS3中使用flex和grid实现等高元素布局的示例代码

《CSS3中使用flex和grid实现等高元素布局的示例代码》:本文主要介绍了使用CSS3中的Flexbox和Grid布局实现等高元素布局的方法,通过简单的两列实现、每行放置3列以及全部代码的展示,展示了这两种布局方式的实现细节和效果,详细内容请阅读本文,希望能对你有所帮助... 过往的实现方法是使用浮动加

c++中std::placeholders的使用方法

《c++中std::placeholders的使用方法》std::placeholders是C++标准库中的一个工具,用于在函数对象绑定时创建占位符,本文就来详细的介绍一下,具有一定的参考价值,感兴... 目录1. 基本概念2. 使用场景3. 示例示例 1:部分参数绑定示例 2:参数重排序4. 注意事项5.

使用C++将处理后的信号保存为PNG和TIFF格式

《使用C++将处理后的信号保存为PNG和TIFF格式》在信号处理领域,我们常常需要将处理结果以图像的形式保存下来,方便后续分析和展示,C++提供了多种库来处理图像数据,本文将介绍如何使用stb_ima... 目录1. PNG格式保存使用stb_imagephp_write库1.1 安装和包含库1.2 代码解

C++实现封装的顺序表的操作与实践

《C++实现封装的顺序表的操作与实践》在程序设计中,顺序表是一种常见的线性数据结构,通常用于存储具有固定顺序的元素,与链表不同,顺序表中的元素是连续存储的,因此访问速度较快,但插入和删除操作的效率可能... 目录一、顺序表的基本概念二、顺序表类的设计1. 顺序表类的成员变量2. 构造函数和析构函数三、顺序表

使用C++实现单链表的操作与实践

《使用C++实现单链表的操作与实践》在程序设计中,链表是一种常见的数据结构,特别是在动态数据管理、频繁插入和删除元素的场景中,链表相比于数组,具有更高的灵活性和高效性,尤其是在需要频繁修改数据结构的应... 目录一、单链表的基本概念二、单链表类的设计1. 节点的定义2. 链表的类定义三、单链表的操作实现四、