劍指offer 複雜鍊錶的複製

2021-08-21 10:03:18 字數 1019 閱讀 3664

請實現函式complexlistnode* clone(complexlistnode* phead),複製乙個複雜鍊錶。

在複雜鍊錶中,每個結點除了有乙個pnext指標指向下乙個結點之外,還有乙個psibling指向鍊錶中的任意結點或者null。

結點的定義如下:

struct complexlistnode;
假設給的複雜鍊錶如下:

複製結點

複製隨機指標

重新連線複製的結點

//複製結點,並連線在複製的那個結點的後邊,它的下乙個結點指向我們複製的結點的下乙個結點

void cloneallnodes(randomlistnode* phead)

}//複製隨機指標

void clonerandom(randomlistnode* phead)

phead = pclone->next;}}

//重新連線複製的結點

randomlistnode* connectallnodes(randomlistnode* phead)

while (pnode !=

null)

return clonephead;}};

劍指offer複雜鍊錶複製

題目描述 輸入乙個複雜鍊錶 每個節點中有節點值,以及兩個指標,乙個指向下乙個節點,另乙個特殊指標指向任意乙個節點 返回結果為複製後複雜鍊錶的head。注意,輸出結果中請不要返回引數中的節點引用,否則判題程式會直接返回空 我的 思路比較笨,就是首先構造乙個正常的不大random指標的鍊錶,然後再去遍歷...

劍指offer 複雜鍊錶複製

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

劍指offer 複雜鍊錶複製

題目描述 輸入乙個複雜鍊錶 每個節點中有節點值,以及兩個指標,乙個指向下乙個節點,另乙個特殊指標指向任意乙個節點 返回結果為複製後複雜鍊錶的head。注意,輸出結果中請不要返回引數中的節點引用,否則判題程式會直接返回空 非遞迴方法 struct randomlistnode randomlistno...