劍指offer 面試題17 合併兩個排序的鍊錶

2021-07-10 20:23:36 字數 1019 閱讀 1220

題目:輸入兩個遞增排序的鍊錶,合併這兩個鍊錶並使新鍊錶中的結點仍然是按照遞增排序的。

思路:每次從兩個鍊錶中選取較小的結點作為新鍊錶的結點,那麼這裡有兩種方法,迴圈或者遞迴。(1)迴圈,每次取出兩個鍊錶中較小的結點插入新鍊錶,到達其中乙個鍊錶的尾結點時,另外乙個鍊錶的其餘部分直接接在這個尾結點上。(2)從兩個鍊錶中選取較小的表頭作為新鍊錶的表頭,那麼剩下的問題就是兩個新的已排序的鍊錶的合併,只不過其中乙個鍊錶的表頭已經後移了乙個結點。這兩個新鍊錶的合併步驟和之前的是一樣的,這就是典型的遞迴過程。

//合併兩個已排序的鍊錶,非遞迴

listnode* mergesortedlist(listnode* plisthead1, listnode* plisthead2)

else

plastnode = newhead;

if (pnode1 == null)

plastnode->m_pnext = pnode2;

if (pnode2 == null)

plastnode->m_pnext = pnode1;

while (pnode1 != null && pnode2 != null)

else

if (pnode1 == null)

plastnode->m_pnext = pnode2;

if (pnode2 == null)

plastnode->m_pnext = pnode1;

}return newhead;

}}

遞迴版本:

//合併兩個已排序的鍊錶,遞迴版本

listnode* mergesortedlist(listnode* phead1, listnode* phead2)

else

return pmergedhead;

}

劍指offer 面試題17

題目 合併兩個排序的單向鍊錶 自己所寫 如下 listnode mergesortedlists listnode phead1,listnode phead2 listnode mergetwolist listnode pfirst,listnode psecond if phead pnext...

劍指offer之面試題17 合併兩個排序的鍊錶

題目描述 輸入兩個單調遞增的鍊錶,輸出兩個鍊錶合成後的鍊錶,當然我們需要合成後的鍊錶滿足單調不減規則。思路 養成好習慣,一旦有鍊錶作為形參傳遞,都要對鍊錶是否為空做判斷,防止空指標異常,至於怎麼處理,稍後會講。當鍊表都不為空時,比較兩個鍊錶的頭結點值的大小,較小者作為新的頭結點儲存,不妨設較小的頭結...

劍指offer 面試題17 合併兩個排序的鍊錶

題目描述 輸入兩個遞增排序的鍊錶,合併這兩個鍊錶並使新鍊錶中的結點仍然是按照遞增排序的。例如鍊錶1,3,5,7和鍊錶2,4,6,8.合併後鍊錶為1,2,3,4,5,6,7,8 題目解析 先是判斷給出的兩個鍊錶是否是空表。然後再比較兩個表的頭結點,小的結點作為頭結點,然後兩個鍊錶依次遍歷,同時比較大小...