思路: 就是正常思路。建立头结点是为了统一(如果第一个结点head
就是需要删除的,那么可能需要分情况讨论。有了头节点就可以统一了)
/**
* Definition for singly-linked list.
* struct ListNode {
* int val;
* ListNode *next;
* ListNode(int x) : val(x), next(NULL) {}
* };
*/
class Solution {
public:
ListNode* deleteNode(ListNode* head, int val) {
// 构建一个头结点 (返回HEAD->next就是删除某节点后的链表)
ListNode* HEAD = new ListNode(100);
HEAD->next = head;
ListNode* pre = HEAD;
ListNode* cur = head;
while(cur->val != val){
pre = cur;
cur = cur->next;
}
pre->next = cur->next;
// free(cur); // 题目说了不需要free
return HEAD->next;
}
};