AB12 删除链表的节点
描述
给定单向链表的头指针和一个要删除的节点的值,定义一个函数删除该节点。返回删除后的链表的头节点。
- 此题对比原题有改动
- 题目保证链表中节点的值互不相同
- 该题只会输出返回的链表和结果做对比,所以若使用C或C++ 语言,你不需要free或delete被删除的节点
数据范围:
0<=链表节点值<=10000
0<=链表长度<=10000
示例:
输入: {2, 5, 1, 9},5
返回值: {2, 1, 9}
我的实现:
首先new一个dummy节点,指向head节点,另外初始化一个node节点进行遍历,对node.next进行判断(或者初始化一个pre节点,一个cur节点,对cur节点进行遍历),值相等则删除nodenext,最后返回dummy.next。
/*
* public class ListNode {
* int val;
* ListNode next = null;
* public ListNode(int val) {
* this.val = val;
* }
* }
*/
public class Solution {
/**
* 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
*
*
* @param head ListNode类
* @param val int整型
* @return ListNode类
*/
public ListNode deleteNode (ListNode head, int val) {
// write code here
ListNode dummy = new ListNode(-1);
dummy.next = head;
ListNode node = dummy;
while (node.next != null) {
if (node.next.val == val) {
node.next = node.next.next;
break;
}
node = node.next;
}
return dummy.next;
}
}