题目描述
返回删除后的链表的头节点。
输入: head = [4,5,1,9], val = 5
输出: [4,1,9]
解释: 给定你链表中值为 5 的第二个节点,那么在调用了你的函数之后,该链表应变为 4 -> 1 -> 9.
解题思路
/**
* Definition for singly-linked list.
* public class ListNode {
* int val;
* ListNode next;
* ListNode(int x) { val = x; }
* }
*/
class Solution {
public ListNode deleteNode(ListNode head, int val) {
// 前一个节点 指向 当前节点的下一个节点
ListNode dummy = new ListNode(0);
dummy.next = head;
ListNode pre = dummy;
ListNode cur = dummy.next;
// 找到val节点
while(cur.val != val && cur != null) {
pre = cur;
cur = cur.next;
}
// 找到val或到头
if(cur != null) {
pre.next = cur.next;
}
return dummy.next;
}
}