題目:輸入乙個鍊錶的頭結點,反轉該鍊錶,並返回反轉後鍊錶的頭結點。鍊錶結點定義如下:
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 當前結點...