题解 | #链表的回文结构#

链表的回文结构

https://www.nowcoder.com/practice/d281619e4b3e4a60a2cc66ea32855bfa

/*
struct ListNode {
    int val;
    struct ListNode *next;
    ListNode(int x) : val(x), next(NULL) {}
};*/

class PalindromeList {
public:
    typedef struct ListNode ListNode;

    ListNode* findnode(ListNode* A)
    {
        ListNode* fast = A,*slow = A;
        while(fast->next && fast)
        {
            slow = slow->next;
            fast = fast->next->next;
        }
        return slow;

    }

    ListNode* reverse(ListNode* mid)
    {
        ListNode* m1 = NULL;
        ListNode* m2 = mid;
        ListNode* m3 = mid->next;
        while(m3)
        {
            m2->next = m1;
            m1 = m2;
            m2 = m3;
            m3 = m3->next;
        }
        return m2;

    }

    bool chkPalindrome(ListNode* A) {
        
        ListNode* mid = findnode(A);
        ListNode* rmid = reverse(mid);
        while(rmid && A)
        {
            if(rmid ->val != A->val)
            {
                return false;
            }
            rmid = rmid->next;
            A = A->next;
        }
        return true;

    }
};

全部评论

相关推荐

10-11 17:45
门头沟学院 Java
走吗:别怕 我以前也是这么认为 虽然一面就挂 但是颇有收获!
点赞 评论 收藏
分享
11-06 10:58
已编辑
门头沟学院 嵌入式工程师
双非25想找富婆不想打工:哦,这该死的伦敦腔,我敢打赌,你简直是个天才,如果我有offer的话,我一定用offer狠狠的打在你的脸上
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务