力扣-234.回文链表

题目描述

给你一个单链表的头节点 head ,请你判断该链表是否为回文链表。如果是,返回 true ;否则,返回 false 。

cpp 复制代码
class Solution {
public:
    bool isPalindrome(ListNode* head) {
        //快慢指针找到中间结点p1(偶数个结点停在中左)
        ListNode* p1 = head;
        ListNode* p2 = head->next;
        if(p2==nullptr)
            return true;
        while (p2!=nullptr&&p2->next!= nullptr){
            p1=p1->next;
            p2=p2->next->next;
        }
        //后半段头插法逆置
        p2=p1->next;
        p1->next=nullptr;
        while (p2!= nullptr){
            ListNode* temp = p2;
            p2=p2->next;
            temp->next=p1->next;
            p1->next=temp;
        }
        //比较前半段与后半段是否重合
        p2=head;
        p1=p1->next;
        while (p1!= nullptr){
            if(p1->val!=p2->val)
                return false;
            p1=p1->next;
            p2=p2->next;
        }
        return true;
    }
};

小结: 这种做法思路比较清晰,而且可以满足O(n) 时间复杂度和 O(1) 空间复杂度

相关推荐
熊猫_豆豆16 小时前
目前顶尖AI所用算法,包含的数学内容,详细列举
人工智能·算法
1白天的黑夜116 小时前
队列+宽搜(BFS)-662.二叉树最大宽度-力扣(LeetCode)
c++·leetcode·宽度优先·队列
野犬寒鸦16 小时前
从零起步学习Redis || 第二章:Redis中数据类型的深层剖析讲解(下)
java·redis·后端·算法·哈希算法
java1234_小锋16 小时前
Scikit-learn Python机器学习 - 回归分析算法 - 弹性网络 (Elastic-Net)
python·算法·机器学习
hn小菜鸡17 小时前
LeetCode 2570.合并两个二维数组-求和法
数据结构·算法·leetcode
hn小菜鸡17 小时前
LeetCode 524.通过删除字母匹配到字典里最长单词
算法·leetcode·职场和发展
Greedy Alg17 小时前
LeetCode 226. 翻转二叉树
算法
我要成为c嘎嘎大王17 小时前
【C++】模版专题
c++·算法
jndingxin17 小时前
算法面试(5)------NMS(非极大值抑制)原理 Soft-NMS、DIoU-NMS 是什么?
人工智能·算法·目标跟踪
苏纪云18 小时前
算法<java>——排序(冒泡、插入、选择、归并、快速、计数、堆、桶、基数)
java·开发语言·算法