leetcode 234

放弃每日一题了。太难坚持了。也许等自己的刷题量达到 1000 题会轻松一些,目前刷题量只有 50 完全吃不消。使用线性空间我也会做,就是一个简单的回文串判断就可以了。第二种做法只需要常数的时间,原理是反转后半段,和前半段进行比较。反转是一个题,并且,反转就是修改指针加上移动,最后当前指针指向空节点,前指针指向原来的最后一个节点。为什么我们要用后半段作为循环终止的条件,因为后半段可能更加短一些,如果前半段为空作为循环终止的条件,有可能出现数组越界的情况,也就是访问空节点来进行比较的错误。每天刷 2 道热门一百的题。整个初试就刷热门一百题。

cpp 复制代码
/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode() : val(0), next(nullptr) {}
 *     ListNode(int x) : val(x), next(nullptr) {}
 *     ListNode(int x, ListNode *next) : val(x), next(next) {}
 * };
 */
class Solution {
public:
    bool isPalindrome(ListNode* head) {
        vector<int> s;
        ListNode* pa;
        for ( pa = head; pa != nullptr; pa = pa->next ) {
            s.push_back( pa->val );
        }
        int left = 0;
        int right = s.size() - 1;
        while ( left < right ) {
            if ( s[left] != s[right] ) {
                return false;
            } else {
                left++;
                right--;
            }
        }
        return true;
    }
};
cpp 复制代码
/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode() : val(0), next(nullptr) {}
 *     ListNode(int x) : val(x), next(nullptr) {}
 *     ListNode(int x, ListNode *next) : val(x), next(next) {}
 * };
 */
class Solution {
public:
    bool isPalindrome(ListNode* head) {
        if ( !head || !head->next ) {
            return true;
        }
        ListNode* slow = head;
        ListNode* fast = head;
        while ( fast->next && fast->next->next ) {
            slow = slow->next;
            fast = fast->next->next;
        }
        ListNode* cur = slow->next;
        ListNode* prev = nullptr;
        while ( cur ) {
            ListNode* next = cur->next;
            cur->next = prev;
            prev = cur;
            cur = next;
        }
        ListNode* p1 = head;
        ListNode* p2 = prev;
        while ( p2 ) {
            if ( p1->val != p2->val ) {
                return false;
            }
            p1 = p1->next;
            p2 = p2->next;
        }
        return true;
    }
};
相关推荐
2601_961875245 分钟前
法考资料2026|全套|资料已整理
数据结构·算法·链表·贪心算法·eclipse·线性回归·动态规划
无限码力10 分钟前
美团研发岗 4月18号笔试真题 - 坐标
算法·美团笔试真题·美团笔试题·美团研发岗笔试题·美团研发岗4月18号真题
有点。1 小时前
C++倍增法(练习题)
c++·算法
智者知已应修善业2 小时前
【51单片机8位数码管同时倒计时从9999】2024-1-25
c++·经验分享·笔记·算法·51单片机
洛水水2 小时前
【力扣100题】86.柱状图中最大的矩形
算法·leetcode·职场和发展
渡之2 小时前
GRiM-Net 深度解析 | 无人机 GNSS 拒止场景下两阶段跨视角视觉定位框架
深度学习·算法·动态规划·无人机
测试仪器廖生135902563852 小时前
罗德与施瓦茨 FSP13频谱分析仪FSP30
网络·人工智能·算法
happymaker06263 小时前
LeetCodeHot100——560.和为K的子数组
算法
dtq04243 小时前
C语言刷题数组5,6(求平均值,求最大值)
c语言·数据结构·算法
郭梧悠3 小时前
Hash算法入门Hash冲突解决方案
算法·哈希算法