合併兩個排序鍊錶

2021-07-29 19:26:21 字數 359 閱讀 3137

先考慮特殊情況,如果乙個鍊錶為空,直接返回另乙個鍊錶;一般情況,新建乙個鍊錶,用兩個指標分別從兩個鍊錶開始迭代,將資料小的放在新鍊錶的後面並且指標後移一位,如果某乙個指標指向null,則直接將另乙個指標連在新鍊錶的後面。

**:/**

* definition of listnode

* class listnode

* }*/

class solution

if (l2== null)

if (l1->val< l2->val) else

}return first->next;}};

感想:

題目雖然簡單,如果沒有考慮全面,有可能會導致越界。

合併兩個排序鍊錶

struct listnode class solution else while pstart1 null pstart2 null plast next pstart1 plast pend1 pend1 pend1 next pstart1 pend1 else plast next psta...

合併兩個排序鍊錶

描述 將兩個排序鍊錶合併為乙個新的排序鍊錶樣例 給出1 3 8 11 15 null,2 null,返回1 2 3 8 11 15 null。解題思路 將兩個鍊錶當中的對應元素的值進行比較,重新確定新鍊錶當中元素的位置。若第乙個鍊錶當前位置的值小於第二個鍊錶當前值,則不需要改變位置,第乙個鍊錶的指標...

合併兩個排序鍊錶

問題描述 將兩個排序鍊錶合併為乙個新的排序鍊錶 樣例 給出1 3 8 11 15 null,2 null,返回1 2 3 8 11 15 null。解題思路 遍歷第二個鍊錶的每乙個節點,然後與第乙個節點的第乙個節點比較,如果第二個鍊錶節點的值小於第乙個,就插入到第乙個煉表裡,如果大於就到下乙個節點。...