leetcode 鍊錶 回文鍊錶

2021-09-26 15:36:18 字數 1218 閱讀 7265

請判斷乙個鍊錶是否為回文鍊錶。

示例 1:

輸入: 1->2

輸出: false

示例 2:

輸入: 1->2->2->1

輸出: true

高階:你能否用 o(n) 時間複雜度和 o(1) 空間複雜度解決此題?

head==null // 空鍊錶,回文,返回true

head.next==null // 只有乙個節點的列表,回文,返回true

fast // 快指標,初始化為head,每次後移2個

slow // 慢指標,初始化為head,每次後移1個

快指標移到最後時,慢指標到達鍊錶中間位置

reversehead // 後半鍊錶反轉後的頭節點

(1)找到鍊錶的中點:利用快慢指標,快指標每次先後移動兩個,慢指標每次向後移動乙個

假設鍊錶長度為n,則後半鍊錶的頭結點位於(n+1)/2+1

(2)利用(1)得到的後半煉表頭結點,反轉後半鍊錶

(3)依次比較後半鍊錶與前半鍊錶,均相等則是回文鍊錶,返回true

//鍊錶長度為奇數,忽略前半鍊錶的最後乙個節點(該情況下 len前鍊錶 = len後鍊錶 + 1)

迴圈直到遇到空節點,將當前節點併入反轉鍊錶

(1)操作前對當前節點的下一節點進行儲存

(2)將當前節點併入反轉鍊錶

(3)變數維護,儲存新的head和p。即

}}**實現參考:

回文鍊錶的實現

鍊錶相關函式

leetcode 鍊錶 回文鍊錶

請判斷乙個鍊錶是否為回文鍊錶。示例 1 輸入 1 2輸出 false示例 2 輸入 1 2 2 1輸出 true高階 你能否用 o n 時間複雜度和 o 1 空間複雜度解決此題?思路 利用快慢指標找到中間節點,當快指標走到末尾時,慢指標指向中間節點 交中間節點之後的節點進行鍊錶反轉 設定指標p1從h...

LeetCode(鍊錶)回文鍊錶 c

請判斷乙個鍊錶是否為回文鍊錶。示例 1 輸入 1 2 輸出 false 示例 2 輸入 1 2 2 1 輸出 true definition for singly linked list.struct listnode class solution 將後半部分鍊錶反轉 listnode temp l...

回文鍊錶 LeetCode

請判斷乙個鍊錶是否為回文鍊錶。你能否用 o n 時間複雜度和 o 1 空間複雜度解決此題?輸入 1 2 2 1 輸出 true 思路 如何判斷回文,從中間位置開始向兩邊不斷判斷相等並移動。關鍵點一 如何找到鍊錶中間位置。採用兩個指標,指標p移動兩格,指標mid移動一格,當p移動終點時,指標mid所在...