鍊錶反轉 58面試「留念」

2021-06-20 07:42:38 字數 1127 閱讀 4939

題目:輸入乙個鍊錶的頭結點,反轉該鍊錶,並返回反轉後鍊錶的頭結點。鍊錶結點定義如下:

struct

listnode

;分析:這是一道廣為流傳的微軟面試題。由於這道題能夠很好的反應出程式設計師思維是否嚴密,在微軟之後已經有很多公司在面試時採用了這道題。

為了正確地反轉乙個鍊錶,需要調整指標的指向。與指標操作相關**總是容易出錯的,因此最好在動手寫程式之前作全面的分析。在面試的時候不急於動手而是一開始做仔細的分析和設計,將會給面試官留下很好的印象,因為在實際的軟體開發中,設計的時間總是比寫**的時間長。與其很快地寫出一段漏洞百出的**,遠不如用較多的時間寫出一段健壯的**。

為了將調整指標這個複雜的過程分析清楚,我們可以借助圖形來直觀地分析。假設下圖中l、m

和n 是三個相鄰的結點:aß

bß…ß

l màn

à…假設經過若干操作,我們已經把結點

l之前的指標調整完畢,這些結點的

m_pnext

指標都指向前面乙個結點。現在我們遍歷到結點

m。當然,我們需要把調整結點的

m_pnext

指標讓它指向結點

l。但注意一旦調整了指標的指向,鍊錶就斷開了,如下圖所示: a

ßbß…

lßm n

à…因為已經沒有指標指向結點

n,我們沒有辦法再遍歷到結點

n了。因此為了避免鍊錶斷開,我們需要在調整m的

m_pnext

之前要把

n儲存下來。

接下來我們試著找到反轉後鍊錶的頭結點。不難分析出反轉後鍊錶的頭結點是原始鍊錶的尾位結點。什麼結點是尾結點?就是

m_pnext

為空指標的結點。

基於上述分析,我們不難寫出如下**:

///// reverse a list iteratively

// input: phead - the head of the original list

// output: the head of the reversed head

///listnode* reverseiteratively(listnode* phead)

return

preversedhead;

}

面試 反轉鍊錶

interview work jobc 經典演算法題目 反轉單鏈表 reverse list 對於乙個普通的單鏈表,可以定義成結構體形式 定義鍊錶節點 struct listnode 請寫乙個函式實現單鏈表的翻轉 題目解析 一般來說,單鏈表的反轉有遞迴和非遞迴的方式來進行實現,此處的反轉實現 參考反...

面試題 反轉鍊錶

定義乙個函式,輸入乙個鍊錶的頭節點,反轉該鍊錶並輸出反轉後鍊錶的頭節點。鍊錶節點定義如下 struct listnode int m nkey listnode m pnext 思路 額,一路遍歷下去,前後指向反過來,最後乙個節點就輸出。o n 的效率也應該是最優的了。答案如下 listnode r...

面試題 反轉鍊錶

面試題 反轉鍊錶 思路 要實現鍊錶反轉,需要調整鍊錶中指標方向,使鍊錶反轉後的頭結點為原鍊錶的尾結點。為了防止結點斷裂,需定義三個指標,分別指向當前遍歷的結點,它的前一結點以及後乙個結點。當然編寫 時要考慮到下列三點 防止程式崩潰 將思路用 實現為 slistnode node phead 當前結點...