劍指 複雜鍊錶的複製

2021-09-13 21:57:14 字數 705 閱讀 9453

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

//1.按順序複製每個節點,並將新節點加到原節點後,比如a->b,得到a->a1->b->b1

while(cur != null)

cur = phead;//重新指向頭

//2.給複製後的節點的隨機指標賦值

while(cur != null)

//3.拆分鍊錶

cur = phead;//重新指向頭

randomlistnode pclonehead = cur.next;//新煉表表頭

while(cur!=null)

return pclonehead;}}

劍指off 複製複雜鍊錶

題目 鍊錶的結構中多了乙個spring指標,這個指標可能指向鍊錶中的任何乙個節點,複製這個複雜鍊錶。分析 首先想到的是第一種方法,複製next串聯起來的鍊錶,然後複製spring 指標,但是每次都要從頭順序查詢spring指標在副本中的值,那麼這個效率應該是o n 2 第二種方法是將副本建立在原來的...

劍指offer複雜鍊錶複製

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

劍指offer 複雜鍊錶複製

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