
目的:移除链表元素
(学习视频分享:java教学视频)
问题介绍:
删除链表中等于给定值 *「val*」 的所有节点。
立即学习“Java免费学习笔记(深入)”;
示例描述:
示例: 输入: 1->2->6->3->4->5->6, val = 6 输出: 1->2->3->4->5
题解思路:
红色扁平化的外贸公司模板 扁平化概念的核心意义是:去除冗余、厚重和繁杂的装饰效果。而具体表现在去掉了多余的透视、纹理、渐变以及能做出3D效果的元素,这样可以让“信息”本身重新作为核心被凸显出来。同时在设计元素上,则强调了抽象、极简和符号化。扁平化的设计,尤其是手机的系统直接体现在:更少的按钮和选项,这样使得UI界面变得更加干净整齐,使用起来格外简洁,从而带给用户更加良好的操作体验。因为可以更加简
36
一个是基于哨兵节点的方式进行解决,另一个是基于java集合的方式来做,本质上还是一样的
程序实现:
import java.util.*;
public class RemoveElementsTest3 {
public static void main(String[] args) {
ListNode l1 = new ListNode(1);
ListNode l2 = new ListNode(2);
ListNode l3 = new ListNode(6);
ListNode l4 = new ListNode(3);
ListNode l5 = new ListNode(4);
ListNode l6 = new ListNode(5);
ListNode l7 = new ListNode(6);
l1.next = l2;
l2.next = l3;
l3.next = l4;
l4.next = l5;
l5.next = l6;
l6.next = l7;
ListNode listNode = removeElements2(l1, 6);
System.out.println("listNode = " + listNode);
}
public static ListNode removeElements(ListNode head, int val) {
ListNode dummyNode = new ListNode(0);
ListNode currentNode = dummyNode;
while (head != null) {
if (head.val != val) {
currentNode.next = head;
currentNode = currentNode.next;
}
head = head.next;
}
currentNode.next = null;
return dummyNode.next;
}
public static ListNode removeElements2(ListNode head, int val) {
List<Integer> list = new LinkedList<>();
while (head != null) {
list.add(head.val);
head = head.next;
}
List<Integer> tempList = new ArrayList<>();
tempList.add(val);
list.removeAll(tempList);
ListNode dummyNode = new ListNode(0);
ListNode tempNode = dummyNode;
for (int i = 0, size = list.size(); i < size; i++) {
ListNode listNode = new ListNode(list.get(i));
tempNode.next = listNode;
tempNode = tempNode.next;
}
return dummyNode.next;
}
}总结:
其实,写到这我觉得你看看整个程序的实现逻辑是很容易看懂的吧,没有什么难点需要推导的,如果不懂的话,可以多调试调试给定的程序,每次输出的内容都是成功运行之后才输出的。
相关推荐:java入门教程
以上就是java实现移除链表元素操作的详细内容,更多请关注php中文网其它相关文章!
java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号