LeetCode 237 删除链表中的节点[链表] HERODING的LeetCode之路

LeetCode 237 删除链表中的节点[链表] HERODING的LeetCode之路_第1张图片解题思路:
这道题目属实有些坑,因为只是传入了需要删除的节点的指针,但是没有原链表!所以这里只能够对需要删除节点进行操作了,我们知道需要删除的节点不是末尾,那好办了,直接伪装成下一个,并把他干掉,那么就完成了删除,代码如下:

/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode(int x) : val(x), next(NULL) {}
 * };
 */
class Solution {
     
public:
    void deleteNode(ListNode* node) {
     
        // 我伪装成下一个
        node -> val = node -> next -> val;
        // 我把下一个吃了
        node -> next = node -> next -> next;
    }
};


/*作者:heroding
链接:https://leetcode-cn.com/problems/delete-node-in-a-linked-list/solution/c-zhi-ru-he-da-ru-di-ren-nei-bu-by-herod-js39/
来源:力扣(LeetCode)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。*/

你可能感兴趣的:(LeetCode,链表,leetcode,单链表,算法,数据结构)