题解 | 链表的回文结构

/*
struct ListNode {
    int val;
    struct ListNode *next;
    ListNode(int x) : val(x), next(NULL) {}
};*/
#include <csetjmp>
class PalindromeList {
public:
    bool chkPalindrome(ListNode* A) {
        struct ListNode* ptr=A;
        int k=0,i=0,j=0;
        while(ptr)
        {
            k++;
            ptr=ptr->next;
        }
        int a=k/2;
        int b=k%2;
        while(A)
        {
            if(a>0 && b==0)
            {
                i+=A->val;
            }
            if(a<=0 && b==0)
            {
                j+=A->val;
            }
            if(a>0 && b==1)
            {
                i+=A->val;
            }
            if(a<0 && b==1)
            {
                j+=A->val;
            }
            a--;
            A=A->next;
        }
       return i==j?true:false;
    }
};

全部评论
能过,但不可取
点赞 回复 分享
发布于 今天 16:32 江西

相关推荐

2024-12-21 18:48
西安邮电大学 C++
黑皮白袜臭脚体育生:按使用了什么技术解决了什么问题,优化了什么性能指标来写会更好另外宣传下自己的开源仿b站微服务项目,GitHub已经390star,牛客上有完整文档教程
点赞 评论 收藏
分享
努力跨行专业的老菜鸡:cxmt给开了31k但是华子开了24k,这两个价格让我纠结要不要毁约cxmt去华为
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务