题目要求:
给定单向链表的头指针和一个要删除的节点的值,定义一个函数删除该节点。返回删除后的链表的头节点。
示例:
输入:head = [4,5,1,9], val = 5
输出:[4,1,9]
解释:给定你链表中值为 5 的第二个节点,那么在调用了你的函数之后,该链表应变为 4 -> 1 -> 9.
-------------------------------------------------------
思路:注释~
class Solution {
public ListNode deleteNode(ListNode head, int val) {
//将头指针另存一下
ListNode temp = head;
//遍历数组找到要删除的节点
boolean flag = true;
while(true){
if(temp.val == val){
return temp.next;
}
if(temp.next.val == val){
flag = false;
break;
}
temp = temp.next;
}
//将下一个指针指向下下个节点
if(flag == false){
temp.next = temp.next.next;
}
//返回链表的头节点
return head;
}
}
执行用时:0 ms, 在所有 Java 提交中击败了100.00% 的用户
内存消耗:40.8 MB, 在所有 Java 提交中击败了71.69% 的用户