链表详解-leetcode203.移除链表元素

链表

移除链表元素

题目:

题意:删除链表中等于给定值 val 的所有节点。

示例 1: 输入:head = [1,2,6,3,4,5,6], val = 6 输出:[1,2,3,4,5]

示例 2: 输入:head = [], val = 1 输出:[]

示例 3: 输入:head = [7,7,7,7], val = 7 输出:[]

在这里插入图片描述

这里的head指的是链表起始的第一个结构体

说明:链表是一个结构体。对于单向链表来说,结构体里存储了val值和连接的下一个结构体的地址next。对于一个cur链表来说,cur就是这个结构体(一个val,一个next)开辟的首地址,也就是存储val的地址即(&(cur->val))的值,而存储val和next的地址是相连的 ,在结构体开辟的地址之后,即(&(cur->val)和&(cur->)) ; 并且cur->next存放的地址是连接的开辟下一个链表结构体的首地址。

在这里插入图片描述

题解:

虚拟头节点:如果第一个元素需要删除,就用到了虚拟头节点

/**
 * 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* dummyHead = new ListNode(0);
        dummyHead->next = head;
        ListNode* cur = dummyHead;
        while (cur->next != NULL) {
            if (cur->next->val == val) {
                // cout<<&(cur->next)<<endl;
                // cout<<&(cur->val)<<endl;
                ListNode* temp = cur->next;
                cur->next = cur->next->next;
                delete temp;

            } else {
                cur = cur->next;
                cout << "val" << &(cur->val) << endl;
                cout << cur << endl;
                cout << "next" << &(cur->next) << endl;
                cout << cur->next << endl;
            }
        }
        head = dummyHead->next;
        delete dummyHead;
        return head;
    }
};

标准输出:

val0x502000000050
0x502000000050
next0x502000000058
0x502000000070
val0x502000000070
0x502000000070
next0x502000000078
0x502000000090
val0x5020000000b0
0x5020000000b0
next0x5020000000b8
0x5020000000d0
val0x5020000000d0
0x5020000000d0
next0x5020000000d8
0x5020000000f0
val0x5020000000f0
0x5020000000f0
next0x5020000000f8
0x502000000110

直接使用原来的链表进行移除节点操作:将第一个节点和后面的节点分开计算。

/**
 * 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) {
        while(head!=NULL&&head->val==val)
        {
            ListNode* temp=head;
            head=head->next;
            delete temp;
        }
        ListNode* cur;
        cur=head;
        while(cur!=NULL&&cur->next!=NULL)  // cur如果是一个空指针  或者说cur没有开辟地址内存 那么cur就没有next的内容 就会报错
        {
            if(cur->next->val==val)
            {
                ListNode* temp=cur->next;
                cur->next=cur->next->next;
                delete temp;

            }
            else{
                cur=cur->next;
            }
        }
        return head;
    }
};

**注意:**当头链表不是要删除的链表的时候,要判断指针(即开辟链表的首地址)是否为空指针,要是空指针那么空指针中的存放地址的next的查询就会报错。

相关推荐

  1. LeetCode203. 元素

    2024-03-21 23:14:02       56 阅读
  2. leetcode203. 元素

    2024-03-21 23:14:02       59 阅读
  3. Leetcode 203 元素

    2024-03-21 23:14:02       62 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-03-21 23:14:02       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-03-21 23:14:02       106 阅读
  3. 在Django里面运行非项目文件

    2024-03-21 23:14:02       87 阅读
  4. Python语言-面向对象

    2024-03-21 23:14:02       96 阅读

热门阅读

  1. OpenCV图像处理模块详解

    2024-03-21 23:14:02       45 阅读
  2. C语言向C++过渡的基础知识(一)

    2024-03-21 23:14:02       49 阅读
  3. QT5信号函数的绑定方式

    2024-03-21 23:14:02       45 阅读
  4. SpringWeb

    SpringWeb

    2024-03-21 23:14:02      35 阅读
  5. 笔记:Mysql 主从搭建

    2024-03-21 23:14:02       42 阅读
  6. 椋鸟数据结构笔记#1:数据结构、顺序表

    2024-03-21 23:14:02       45 阅读
  7. SpringBoot注解

    2024-03-21 23:14:02       50 阅读
  8. 蓝桥杯算法基础(28)11道关于字符串的小题

    2024-03-21 23:14:02       36 阅读
  9. rocketmq 4.9.6安装

    2024-03-21 23:14:02       48 阅读
  10. 手势追踪技术在HTC VIVE中的应用与实现

    2024-03-21 23:14:02       46 阅读
  11. 7 Internet基础(2)

    2024-03-21 23:14:02       44 阅读