/**
* 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
}