您好,登錄后才能下訂單哦!
小編給大家分享一下java實現移除鏈表元素的方法,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!
目的:移除鏈表元素
問題介紹:
刪除鏈表中等于給定值 *「val*」 的所有節點。
示例描述:
示例: 輸入: 1->2->6->3->4->5->6, val = 6 輸出: 1->2->3->4->5
題解思路:
一個是基于哨兵節點的方式進行解決,另一個是基于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實現移除鏈表元素的方法”有了一定的了解,如果想了解更多相關知識,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。