每日一算法之判断回文联表
请判断一个链表是否为回文链表。
示例 1:
1 | 输入: 1->2 |
示例 2:
1 | 输入: 1->2->2->1 |
进阶:
你能否用 O(n) 时间复杂度和 O(1) 空间复杂度解决此题?(leetcode原题)
拿到这个题的时候,看到给出的第二个示例以及要求O(1) 空间复杂度就知道要利用链表逆序思想,将链表后半部分逆序。然后从前到中和从后到中一一对比即可。
实现代码:
1 | /** |
好久没有写算法了,为了链表的逆序在纸上画了半天才理清逻辑。。。
请判断一个链表是否为回文链表。
示例 1:
1 | 输入: 1->2 |
示例 2:
1 | 输入: 1->2->2->1 |
进阶:
你能否用 O(n) 时间复杂度和 O(1) 空间复杂度解决此题?(leetcode原题)
拿到这个题的时候,看到给出的第二个示例以及要求O(1) 空间复杂度就知道要利用链表逆序思想,将链表后半部分逆序。然后从前到中和从后到中一一对比即可。
实现代码:
1 | /** |
好久没有写算法了,为了链表的逆序在纸上画了半天才理清逻辑。。。