面试题 02.06. 回文链表

题目来源:

leetcode题目,网址:面试题 02.06. 回文链表 - 力扣(LeetCode)

解题思路:

快慢指针,快指针指向第二个节点,慢指针指向第一个节点。然后快指针每次向后移动两个节点,慢指针向后移动一个节点的同时翻转前面的链表。最后遍历前半个链表和后半个链表比较即可。

解题代码:

复制代码
/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode(int x) : val(x), next(NULL) {}
 * };
 */
class Solution {
public:
    bool isPalindrome(ListNode* head) {
       if(head==nullptr || head->next==nullptr){
           return true;
       }
       ListNode* pre=nullptr;
       ListNode* slow=head;
       ListNode* quick=head->next;
       ListNode* formor=nullptr;
       ListNode* latter=nullptr;
       while(quick!=nullptr){
           quick=quick->next;
           ListNode* temp=slow->next; 
           slow->next=pre;
           pre=slow;
           slow=temp;
           if(quick==nullptr){
               latter=slow;
               formor=pre;
           }else{
               quick=quick->next;
               if(quick==nullptr){
                   latter=slow->next;
                   formor=pre;
               }
           }
       }
       while(formor!=nullptr){
           if(formor->val!=latter->val){
               return false;
           }
           formor=formor->next;
           latter=latter->next;
       }
        return true;
    }
};
复制代码

总结:

官方题解给出了三种解法。第一种是复制到数组中后用双指针。第二种是递归比较。第三种是快慢指针。


相关推荐
Epiphany.5562 分钟前
连通块的遍历
c++·算法·蓝桥杯
史迪仔011220 分钟前
[QML] Qt6/Qt5四大渐变效果实战指南
开发语言·前端·c++·qt
大大杰哥26 分钟前
leetcode hot100(2)双指针,滑动窗口
数据结构·算法·leetcode
风筝在晴天搁浅29 分钟前
LeetCode CodeTop 113.路径总和Ⅱ
算法·leetcode
张赫轩(不重名)30 分钟前
加权重心(换根DP)
c++·算法·动态规划·图论
水木流年追梦34 分钟前
【python因果库实战26】逆概率加权模型1
开发语言·python·算法·leetcode
2401_8401052037 分钟前
题解: [GESP202409 八级] 美丽路径
数据结构·c++·算法·动态规划
SiYuanFeng1 小时前
面试大厂leetcode重点题型简洁明快复习(dfs/bfs,动态规划,链表,滑动窗口/双指针,回溯,ACM型输入输出,二分)
leetcode·面试·coding
YYYing.1 小时前
【C++项目之高并发内存池 (三)】万字解析CentralCache与PageCache的初步实现
c++·笔记·哈希算法·高并发·c/c++·内存池
Chase_______1 小时前
【算法】LeetCode 1052 & 3679:定长滑动窗口进阶——增益最大化与频率约束贪心
算法·leetcode