劍指Offer 25 複雜鍊錶的複製

2022-08-19 16:30:14 字數 627 閱讀 5897

輸入乙個複雜鍊錶(每個節點中有節點值,以及兩個指標,乙個指向下乙個節點,另乙個特殊指標指向任意乙個節點),返回結果為複製後複雜鍊錶的head。(注意,輸出結果中請不要返回引數中的節點引用,否則判題程式會直接返回空)

首先遍歷結點同時,複製結點插入原來的結點的後面。然後再遍歷一遍,根據原來的結點的指標關係,設定特殊指標。如果原來乙個結點 a 的特殊指標指向 b,那麼其複製結點 a' 指向 b 的 next,也即 b'。遍歷完成的,將複製的結點從原來的鍊錶中分離出來。

/*鍊錶結點的定義*/

public class randomlistnode

}/*實現*/

public class solution

//adjust special pointer

p = phead;

while (p != null)

//seprate from the list

randomlistnode newhead = null;

p = phead;

randomlistnode q = newhead;

while (p != null)

return newhead;

}}

劍指offer 25 複雜鍊錶的複製

輸入乙個複雜鍊錶 每個節點中有節點值,以及兩個指標,乙個指向下乙個節點,另乙個特殊指標指向任意乙個節點 返回結果為複製後複雜鍊錶的head。注意,輸出結果中請不要返回引數中的節點引用,否則判題程式會直接返回空 include include include using namespace std s...

劍指offer 25 複雜鍊錶的複製

輸入乙個複雜鍊錶 每個節點中有節點值,以及兩個指標,乙個指向下乙個節點,另乙個特殊指標指向任意乙個節點 返回結果為複製後複雜鍊錶的head。注意,輸出結果中請不要返回引數中的節點引用,否則判題程式會直接返回空 本題的最簡答的思路就是先實現結點與next指標的複製,然後利用遍歷整個鍊錶尋找每個結點的r...

劍指offer 25 複雜鍊錶的複製

輸入乙個複雜鍊錶 每個節點中有節點值,以及兩個指標,乙個指向下乙個節點,另乙個特殊指標指向任意乙個節點 返回結果為複製後複雜鍊錶的head。注意,輸出結果中請不要返回引數中的節點引用,否則判題程式會直接返回空 1 複製每個節點,如 複製節點a得到a1,將a1插入節點a後面 2 遍歷鍊錶,a1 ran...