LeetCode 回文鍊錶

2022-09-09 15:54:27 字數 1512 閱讀 4337

給你乙個單鏈表的頭節點 head ,請你判斷該鍊錶是否為回文鍊錶。如果是,返回 true ;否則,返回 false 。

示例 1:

輸入:head = [1,2,2,1]

輸出:true

示例 2:

輸入:head = [1,2]

輸出:false

1

/**2

* definition for singly-linked list.

3* public class listnode

7* listnode(int val)

8* listnode(int val, listnode next)

9* }

10*/

11class

solution

17//

找到前半段尾節點(奇數為中間,偶數為前半段最後乙個)

18 listnode firsthalfend =firsthalfend(head);

19//

翻轉後半段的鍊錶

20 listnode reversenode =reverselist(firsthalfend.next);

21//

比較兩條鍊錶

22//

為了復原鍊錶

23boolean result = true

;24 listnode p1 =head;

25 listnode p2 =reversenode;

26while (result && p2!= null

)30 p1 =p1.next;

31 p2 =p2.next;32}

33//

將鍊錶復原

34 firsthalfend.next =reverselist(reversenode);

35return

result;36}

37//

翻轉後半段的鍊錶

38public

listnode reverselist(listnode head)

47return

prev;48}

4950

//通過快慢指標找到前半部分鍊錶的尾節點

51public

listnode firsthalfend(listnode head)

58return

slow;59}

60 }

解題關鍵:1.找到前半段的尾節點

2.翻轉後半段鍊錶

3.比對前後鍊錶

leetcode 鍊錶 回文鍊錶

請判斷乙個鍊錶是否為回文鍊錶。示例 1 輸入 1 2 輸出 false 示例 2 輸入 1 2 2 1 輸出 true 高階 你能否用 o n 時間複雜度和 o 1 空間複雜度解決此題?head null 空鍊錶,回文,返回true head.next null 只有乙個節點的列表,回文,返回tru...

leetcode 鍊錶 回文鍊錶

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

回文鍊錶 LeetCode

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