劍指Offer 複雜鍊錶的複製

2021-08-02 19:43:16 字數 1049 閱讀 8828

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

這個題目主要的難點在於隨機指向的這個節點如何去複製到另乙個鍊錶中去,那麼,這裡如果單純的採用直接賦值拷貝的方式肯定是不可取的,因為這個方式的話需要遍歷整個鍊錶確定每個元素指向了第幾個元素然後再次掃瞄並進行修改指向,這當然肯定不是最好的解決辦法。

既然要複製,那麼平行的將每個元素複製乙份作為乙個拷貝,作為其原來元素的next插入到原來的鍊錶中去,這樣的話就形成了,a->a`->b->b`的鍊錶,那麼,在複製的過程中我們可以同時拷貝a的random來記錄其random指向,注意random可以在後面做向後移動乙個元素的方式進行獲取。

所以這個題分兩個步驟,

1.複製所有元素並將其新增為原來元素的next節點,同時複製random指向。

2.刪除鍊錶中原來的節點,將新的節點取出來,並且,鍊錶中的random和next全部向後面平移一位。

/*

public class randomlistnode }*/

public class solution

randomlistnode node = phead;

while(node != null)

node = phead;

int count = 0;

randomlistnode head = null;

randomlistnode temp = null;

while(node != null)

if(node.random != null)

temp = node.next;

if(node.next != null)

node = temp;

} else

count ++;

}phead.next = null;

return head;

}}

劍指offer複雜鍊錶複製

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

劍指offer 複雜鍊錶複製

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

劍指offer 複雜鍊錶複製

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