摘要:注意因為堆中是鏈表節(jié)點,我們在初始化堆時還要新建一個的類。代碼初始化大小為的堆拿出堆頂元素將堆頂元素的下一個加入堆中
Merge Two Sorted Lists 最新更新請見:https://yanjia.me/zh/2019/01/...
Merge two sorted linked lists and return it as a new list. The new list should be made by splicing together the nodes of the first two lists.依次拼接 復(fù)雜度
時間 O(N) 空間 O(1)
思路該題就是簡單的把兩個鏈表的節(jié)點拼接起來,我們可以用一個Dummy頭,將比較過后的節(jié)點接在這個Dummy頭之后。最后如果有沒比較完的,說明另一個list的值全比這個list剩下的小,而且拼完了,所以可以把剩下的直接全部接上去。
代碼public class Solution { public ListNode mergeTwoLists(ListNode l1, ListNode l2) { // 創(chuàng)建一個dummy頭,從后面開始接 ListNode dummy = new ListNode(0); ListNode curr = dummy; // 依次比較拼接 while(l1 != null && l2 != null){ if(l1.val <= l2.val){ curr.next = l1; l1 = l1.next; } else { curr.next = l2; l2 = l2.next; } curr = curr.next; } // 把剩余的全拼上去 if(l1 == null){ curr.next = l2; } else if (l2 == null){ curr.next = l1; } return dummy.next; } }Merge k Sorted Lists
最新解法請見:https://yanjia.me/zh/2019/01/...
優(yōu)先隊列 復(fù)雜度Merge k sorted linked lists and return it as one sorted list. Analyze and describe its complexity.
Example:Input: [ 1->4->5, 1->3->4, 2->6 ] Output: 1->1->2->3->4->4->5->6
時間 O(NlogK) 空間 O(K)
思路當(dāng)我們歸并k個列表時,最簡單的方法就是,對于每次插入,我們遍歷這K個列表的最前面的元素,找出K個中最小的再加入到結(jié)果中。不過如果我們用一個優(yōu)先隊列(堆),將這K個元素加入再找堆頂元素,每次插入只要logK的復(fù)雜度。當(dāng)拿出堆頂元素后,我們再將它所在鏈表的下一個元素拿出來,放到堆中。這樣直到所有鏈表都被拿完,歸并也就完成了。
注意因為堆中是鏈表節(jié)點,我們在初始化堆時還要新建一個Comparator的類。
代碼Java
public class Solution { public ListNode mergeKLists(ListNode[] lists) { if(lists.length == 0) return null; ListNode dummy = new ListNode(0); PriorityQueueq = new PriorityQueue (11, new Comparator (){ public int compare(ListNode n1, ListNode n2){ return n1.val - n2.val; } }); // 初始化大小為k的堆 for(int i = 0; i < lists.length; i++){ if(lists[i] != null) q.offer(lists[i]); } ListNode curr = dummy; while(!q.isEmpty()){ // 拿出堆頂元素 curr.next = q.poll(); curr = curr.next; // 將堆頂元素的下一個加入堆中 if(curr.next != null){ q.offer(curr.next); } } return dummy.next; } }
Python
class HeapItem: def __init__(self, node): self.node = node self.val = node.val def __lt__(self, other): return self.val < other.val class Solution: def mergeKLists(self, lists): """ :type lists: List[ListNode] :rtype: ListNode """ heap = [] for node in lists: if node is not None: heap.append(HeapItem(node)) heapify(heap) dummy = ListNode(0) head = dummy while len(heap) != 0: item = heappop(heap) node = item.node head.next = node head = head.next if node.next is not None: heappush(heap, HeapItem(node.next)) return dummy.next
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/64516.html
摘要:思路這題中的中,個還有其中個別的等于的情況,所以要判斷一下再加入代碼 Merge k sorted linked lists and return it as one sorted list. Analyze and describe its complexity. Heap Time Complexity: Update the heap costs O(nklogk) Space ...
摘要:為減小空間復(fù)雜度,最后結(jié)果直接修改在上,不重新給分配空間。 Easy 021 Merge Two Sorted Lists Description: Merge two sorted linked lists and return it as a new list. The new list should be made by splicing together the nodes o...
摘要:先考慮和有無空集,有則返回另一個。新建鏈表,指針將和較小的放在鏈表頂端,然后向后遍歷,直到或之一為空。再將非空的鏈表放在后面。 Problem Merge two sorted (ascending) linked lists and return it as a new sorted list. The new sorted list should be made by splici...
摘要:題目要求翻譯過來就是將兩個有序的鏈表組合成一個新的有序的鏈表思路一循環(huán)在當(dāng)前兩個鏈表的節(jié)點都是非空的情況下比較大小,較小的添入結(jié)果鏈表中并且獲得較小節(jié)點的下一個節(jié)點。 題目要求 Merge two sorted linked lists and return it as a new list. The new list should be made by splicing togeth...
摘要:題目詳情題目要求我們將兩個有序鏈表合成一個有序的鏈表。輸入輸出想法首先要判斷其中一個鏈表為空的狀態(tài),這種情況直接返回另一個鏈表即可。每次遞歸都會獲得當(dāng)前兩個鏈表指針位置的值較小的節(jié)點,從而組成一個新的鏈表。 題目詳情 Merge two sorted linked lists and return it as a new list. The new list should be mad...
閱讀 1765·2021-09-27 14:02
閱讀 3181·2021-09-27 13:36
閱讀 1056·2019-08-30 12:46
閱讀 1843·2019-08-30 10:51
閱讀 3583·2019-08-29 17:02
閱讀 955·2019-08-29 16:38
閱讀 1856·2019-08-29 16:37
閱讀 3034·2019-08-26 10:32