【手撕力扣链表题】移除链表元素,反转链表(6/98)

简介: 【手撕力扣链表题】移除链表元素,反转链表(6/98)

05d250eb22e3badf2cfb05fc5f2f91af_94536690f848438fab30aa17191a6ea2.png

目前进度:

e97e8f5516dd8764f009964df7fb57a8_9708c5ff8ebd42c9953753205d44d217.png

05d250eb22e3badf2cfb05fc5f2f91af_94536690f848438fab30aa17191a6ea2.png

🌺203. 移除链表元素


🍁题目描述


给你一个链表的头节点 head 和一个整数 val ,请你删除链表中所有满足 Node.val == val 的节点,并返回 新的头节点 。


示例 1:


ef90512b03c244ac211fe7ab9090b9c1_fbc2f4e37ea34aecba0e29a7782e780c.png


输入: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

输出:[]


提示:


   列表中的节点数目在范围 [0, 104] 内

   1 <= Node.val <= 50

   0 <= val <= 50


🍁基础框架


C++ 版本给出的基础框架代码如下:

/**
 * 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) {
    }
};


🍁详细思路


🍀思路一【迭代】


用 temp表示当前节点。如果 temp 的下一个节点不为空且下一个节点的节点值等于给定的 val,则需要删除下一个节点。


💬 代码演示


/**
 * 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) {
        struct ListNode* Head = new ListNode(0, head);
        struct ListNode* temp = Head;
        while (temp->next != NULL) 
        {
            if (temp->next->val == val)
            {
                temp->next = temp->next->next;
            } else 
            {
                temp = temp->next;
            }
        }
        return Head->next;
    }
};


🍀思路二【递归】


递归三部曲


递归结束条件

找到函数的等价关系式

调用函数

(1)当head为空时返回head


(2)不为空时,递归地进行删除操作。


(3)调用函数


💬 代码演示


class Solution {
public:
    ListNode* removeElements(ListNode* head, int val) {
        if (head == nullptr) {
            return head;
        }
        head->next = removeElements(head->next, val);
        return head->val == val ? head->next : head;
    }
};


🌺206. 反转链表


🍁题目描述


给你单链表的头节点 head ,请你反转链表,并返回反转后的链表。


示例 1:


4fe447ada7038b0dc6df52c2903d85f6_abe0a65ab0d3435f9981455769e25479.png


输入:head = [1,2,3,4,5]

输出:[5,4,3,2,1]


示例 2:


8d8e2c0ecfca0f02c690af74eaa58638_75d11a4354104c87948a286b8b645b9e.png


输入:head = [1,2]

输出:[2,1]


示例 3:


输入:head = []

输出:[]


提示:


   链表中节点的数目范围是 [0, 5000]

   -5000 <= Node.val <= 5000


🍁基础框架


C++ 版本给出的基础框架代码如下:

/**
 * 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* reverseList(ListNode* head) {
    }
};


🍁详细思路


🍀思路一【迭代】

.

翻转链表只需要把每一个指针的指向反过来就行了,我们定义两个指针,一个指向前一结点,另一个指向当前结点,然后进行反向操作即可。


💬 代码演示


/**
 * 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* reverseList(ListNode* head) {
        ListNode* prev = nullptr;
        ListNode* curr = head;
        while (curr) {
            ListNode* next = curr->next;
            curr->next = prev;
            prev = curr;
            curr = next;
        }
        return prev;
    }
};


🍀思路二【递归】


递归三部曲


递归结束条件,

找到函数的等价关系式

调用函数

(1)当头结点或第二个结点为空的时候,返回头结点


(2)在返回的过程中,让当前结点的下一个结点的next指向当前结点,当前结点的next指向NULL,实现局部翻转。


(3)调用函数


💬 代码演示


/**
 * 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* reverseList(ListNode* head) {
        if (!head || !head->next) 
        {
            return head;
        }
        ListNode* newHead = reverseList(head->next);
        head->next->next = head;
        head->next = nullptr;
        return newHead;
    }
};


05d250eb22e3badf2cfb05fc5f2f91af_94536690f848438fab30aa17191a6ea2.png


本人不才,如有错误,欢迎各位大佬在评论区指正。有帮助的话还请【关注➕点赞➕收藏】,不行的话我再努努力💪💪💪    


相关文章
|
3天前
|
存储
力扣 合并两个有序数列||移除元素
力扣 合并两个有序数列||移除元素
10 0
|
4天前
LeetCode链表hard 有思路?但写不出来?
LeetCode链表hard 有思路?但写不出来?
|
5天前
|
索引
每日一题:力扣328. 奇偶链表
每日一题:力扣328. 奇偶链表
14 4
|
5天前
leetcode代码记录(下一个更大元素 II
leetcode代码记录(下一个更大元素 II
8 0
|
5天前
|
索引
leetcode代码记录(下一个更大元素 I
leetcode代码记录(下一个更大元素 I
8 0
|
5天前
leetcode代码记录(移除链表元素
leetcode代码记录(移除链表元素
10 0
|
5天前
leetcode代码记录(移除元素
leetcode代码记录(移除元素
11 0
【每日一题】LeetCode——反转链表
【每日一题】LeetCode——反转链表
【每日一题】LeetCode——链表的中间结点
【每日一题】LeetCode——链表的中间结点
|
5天前
|
C++
[leetcode 链表] 反转链表 vs 链表相交
[leetcode 链表] 反转链表 vs 链表相交