1.题目:
给你一个链表的头节点 head
和一个整数 val
,请你删除链表中所有满足 Node.val == val
的节点,并返回 新的头节点 。
示例:
输入:head = [1,2,6,3,4,5,6], val = 6
输出:[1,2,3,4,5]
2.代码实现
/**
* Definition for singly-linked list.
* public class ListNode {
* int val;//定义当前结点的值
* ListNode next;//下一个节点
* ListNode() {}
* ListNode(int val) { this.val = val; }
* ListNode(int val, ListNode next) { this.val = val; this.next = next; }
* }
*/
class Solution {
public ListNode removeElements(ListNode head, int val) {
ListNode dummyHead = new ListNode();//创建一个虚拟头结点
dummyHead.next = head;//把虚拟头结点的后一位定义为头结点
ListNode cur = dummyHead;//再定义一个指针来移动遍历,不能直接用dummyHead,因为dummyHead最后要返回
while(cur.next != null){//这里是循环的条件,是当当前指针的后一个结点里的地址是null时,就是链表遍历完成
if(cur.next !=null && cur.next.val==val){
//这里的条件是cur的下一个结点不为空,否则的话会出现空指针异常
cur.next = cur.next.next;//表示删除当前指针的后一个元素
}else{
cur = cur.next;//表示让指针往后移动一位
}
}
return dummyHead.next;//最后返回新的头结点,注意是虚拟头结点的后一个节点
}
}
3.图解: