LeetCode 203.移除链表元素

题目描述

删除链表中等于给定值 val 的所有节点。

示例:

1
2
输入: 1->2->6->3->4->5->6, val = 6
输出: 1->2->3->4->5

解决方案

方法一:使用头结点

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
/*public class ListNode {
int val;
ListNode next;
ListNode(int x) { val = x; }
}*/
class Solution {
public ListNode removeElements(ListNode head, int val) {
ListNode root = new ListNode(0);
root.next = head;
ListNode node = root;
while(node.next != null) {
if(node.next.val == val) {
node.next = node.next.next;
} else {
node = node.next;
}
}
return root.next;
}
}

方法二:不使用头结点

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
/*public class ListNode {
int val;
ListNode next;
ListNode(int x) { val = x; }
}*/
class Solution {
public ListNode removeElements(ListNode head, int val) {
if(head == null) {
return head;
}
// pre表示node的前驱结点
ListNode node = head, pre = head;
while(node != null) {
if(node.val == val) {
// 若头结点需要删除
if(node == head) {
head = head.next;
} else {
pre.next = node.next;
}
} else {
pre = node;
}
node = node.next;
}
return head;
}
}

方法三:递归法

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
/*public class ListNode {
int val;
ListNode next;
ListNode(int x) { val = x; }
}*/
class Solution {
public ListNode removeElements(ListNode head, int val) {
if(head == null) {
return head;
}
// 若头结点需要删除
if(head.val == val) {
return removeElements(head.next, val);
}
head.next = removeElements(head.next, val);
return head;
}
}

----------本文结束感谢您的阅读----------
坚持原创技术分享,您的支持将鼓励我继续创作!