Q:
给你一个链表的头节点 head
和一个整数val
,请你删除链表中所有满足 Node.val == 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
输出:[]
S:
/**
* Definition for singly-linked list.
* struct ListNode {
* int val;
* struct ListNode *next;
* };
*/
struct ListNode* removeElements(struct ListNode* head, int val){
if(head==NULL)
return NULL;
struct ListNode* tail=head;
struct ListNode* prev=NULL;
while(tail)
{
if(tail->val==val)
{
//头删
if(tail==head)
{
head=tail->next;
free(tail);
tail=head;
}
//中间删
else
{
prev->next=tail->next;
free(tail);
tail=prev->next;
}
}
else
{
prev=tail;
tail=tail->next;
}
}
return head;
}