请编写一个函数,使其可以删除某个链表中给定的(非末尾)节点,你将只被给定要求被删除的节点。
现有一个链表 – head = [4,5,1,9],它可以表示为:
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/delete-node-in-a-linked-list
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
题意就是给出一个节点,然后让把这个节点在链表中删去,因为我们通常思维下删除一个节点都是直接让前一个指针的next指向下一个指针
pre->next = node->next;
但是这个题就给了一个节点,也就是前面的链表根本没有给出,所以很懵。
实际上很简单,就把后一个节点的val赋给当前节点,然后再让当前节点指向下一节点的下一节点就可以了(禁止套娃
/**
* 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;
}
};