Leetcode21 合併兩個有序鍊錶(C語言)

2021-10-02 16:52:48 字數 627 閱讀 8705

資料結構-鍊錶:演算法與資料結構參考

題目:

將兩個有序鍊錶合併為乙個新的有序鍊錶並返回。新煉表是通過拼接給定的兩個鍊錶的所有節點組成的。 示例:

輸入:1->2->4, 1->3->4

輸出:1->1->2->3->4->4

思路:

利用遞迴處理(可以把一組數看作 第乙個數 和 剩下的數 兩個元素進行處理)

遞迴步驟

說明(本題為例)

1.明確函式功能

合併兩個有序鍊錶

2.遞迴結束條件

遍歷完兩個鍊錶

3.函式等價關係

第n個數和第n-1個數之間的關係

**:

/**

* definition for singly-linked list.

* struct listnode ;

*/struct listnode*

mergetwolists

(struct listnode* l1,

struct listnode* l2)

else

}

LeetCode 21合併兩個有序列表

將兩個公升序鍊錶合併為乙個新的公升序鍊錶並返回。新煉表是通過拼接給定的兩個鍊錶的所有節點組成的。輸入 1 2 4,1 3 4 輸出 1 1 2 3 4 4初始解法 這個問題轉換為經典的merge排序中的merge過程.merge排序中merge操作即是將兩個有序子陣列合併成乙個陣列,需要考慮比較過程...

leetcode21 合併兩個有序鍊錶

將兩個有序鍊錶合併為乙個新的有序鍊錶並返回。新煉表是通過拼接給定的兩個鍊錶的所有節點組成的。示例 輸入 1 2 4,1 3 4 輸出 1 1 2 3 4 4 思路 每次判斷兩個鍊錶的頭部小的數值,訪問小的,並讓該鍊錶往後移動。注意 注意鍊錶走完,為空的情況即可。遇到的問題 一開始不太理解鍊錶,返回e...

LEETCODE 21 合併兩個有序鍊錶

將兩個有序鍊錶合併為乙個新的有序鍊錶並返回。新煉表是通過拼接給定的兩個鍊錶的所有節點組成的。示例 輸入 1 2 4,1 3 4 輸出 1 1 2 3 4 4c 第一遍將 相等 的這個else分支寫錯了,主要錯誤在於,next指標指向下乙個的這條語句寫到了後面,導致節點自己指向自己,造成了超時錯誤 執...