题解 | #删除链表的节点#
删除链表的节点
https://www.nowcoder.com/practice/f9f78ca89ad643c99701a7142bd59f5d
/**
* struct ListNode {
* int val;
* struct ListNode *next;
* };
*/
/**
* 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
*
*
* @param head ListNode类
* @param val int整型
* @return ListNode类
*/
struct ListNode* deleteNode(struct ListNode* head, int val ) {
struct ListNode*p=head;
if(head->val==val)
return head->next;
while(p->next){
if(p->next->val!=val)
p=p->next;
else{
p->next=p->next->next;//这里next->next并不会导致null错误,只要不是null=null->next,不给null赋值就行
break;//因为结点val各不相同,所以删完这个就没了,跳出循环
}
}
return head;// write code here
}
字节跳动成长空间 989人发布