合併兩個有序連結串列JavaScript
阿新 • • 發佈:2019-01-03
這道題也是為了熟悉JavaScript連結串列的操作等等。在生成一個新的連結串列時,提供一個常數作為引數,避免了在直接輸入l1或者l2的頭結點時還需要邏輯判斷的複雜情況。直接在最後返回時,從該連結串列的第二個開始返回。
而判斷進行排序的過程還是比較簡單,直接比較l1和l2中結點的大小就好。
/**
* Definition for singly-linked list.
* function ListNode(val) {
* this.val = val;
* this.next = null;
* }
*/
/**
* @param {ListNode} l1
* @param {ListNode} l2
* @return {ListNode}
*/
var mergeTwoLists = function(l1, l2) {
var l3 = new ListNode(-1);
var c3 = l3;
while(l1 !== null && l2 !== null) {
if(l1.val <= l2.val) {
c3.next = l1;
l1 = l1.next;
} else {
c3.next = l2;
l2 = l2.next;
}
c3 = c3.next;
}
//迴圈完某一連結串列後,將另一連結串列剩下的部分直接加入到l3
c3.next = (l1===null) ? l2 : l1;
return l3.next;
};