您好,登錄后才能下訂單哦!
這期內容當中小編將會給大家帶來有關LeetCode中怎么移除重復節點,文章內容豐富且以專業的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。
編寫代碼,移除未排序鏈表中的重復節點。保留最開始出現的節點。
示例1:
輸入:[1, 2, 3, 3, 2, 1]
輸出:[1, 2, 3]
示例2:
輸入:[1, 1, 1, 1, 2]
輸出:[1, 2]
提示:
鏈表長度在[0, 20000]范圍內。
鏈表元素在[0, 20000]范圍內。
哨兵節點,LinkedHashSet集合的使用
import java.util.LinkedHashSet;
import java.util.Set;
public class RemoveDuplicateNodesTest {
public static void main(String[] args) {
ListNode l1 = new ListNode(1);
ListNode l2 = new ListNode(2);
ListNode l3 = new ListNode(3);
ListNode l4 = new ListNode(3);
ListNode l5 = new ListNode(2);
ListNode l6 = new ListNode(1);
l1.next = l2;
l2.next = l3;
l3.next = l4;
l4.next = l5;
l5.next = l6;
ListNode listNode = removeDuplicateNodes(l1);
System.out.println("listNode = " + listNode);
}
public static ListNode removeDuplicateNodes(ListNode head) {
if (head == null || head.next == null) {
return head;
}
Set<Integer> hashSet = new LinkedHashSet<>();
while (head != null) {
hashSet.add(head.val);
head = head.next;
}
ListNode dummyNode = new ListNode(-1);
ListNode tempNode = dummyNode;
for (Integer num : hashSet) {
ListNode listNode = new ListNode(num);
tempNode.next = listNode;
tempNode = tempNode.next;
}
return dummyNode.next;
}
}
上述就是小編為大家分享的LeetCode中怎么移除重復節點了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。