题目链接:234. 回文链表 - 力扣(LeetCode)
题目:
题解:
currentNode 指针是先到尾节点,由于递归的特性再从后往前进行比较。frontPointer 是递归函数外的指针。若 currentNode.val != frontPointer.val 则返回 false。反之,frontPointer 向前移动并返回 true。
算法的正确性在于递归处理节点的顺序是相反的(回顾上面打印的算法),而我们在函数外又记录了一个变量,因此从本质上,我们同时在正向和逆向迭代匹配。
时间复杂度:O(n),其中 n 指的是链表的大小。
空间复杂度:O(n),其中 n 指的是链表的大小。计算机在递归的过程中将使用堆栈的空间
(在进行回文检查之前,递归函数将在堆栈中创建 n 个堆栈帧,计算机会逐个弹出进行处理。所以在使用递归时空间复杂度要考虑堆栈的使用情况)。
代码:
class Solution {ListNode* frontPointer;
public:bool check(ListNode* currentNode){if(currentNode!=nullptr){if(!check(currentNode->next))//先递归到最后位置,后逆向迭代{return false;}if(currentNode->val!=frontPointer->val)//匹配是否为回文{return false;}frontPointer=frontPointer->next;//正向}return true;}bool isPalindrome(ListNode* head) {frontPointer=head; //保存第一个位置结点return check(head);}
};