1. 程式人生 > >合併兩個有序連結串列JavaScript

合併兩個有序連結串列JavaScript

這道題也是為了熟悉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; };