[编程题]回文链表

回文链表

http://www.nowcoder.com/questionTerminal/baefd05def524a92bcfa6e1f113ed4f0

从两边往中间比:递归到最后一个再开始比较

private  ListNode head = null;
public  boolean isPalindrome(ListNode pHead) {
    if (head == null) head = pHead;
    if (pHead.next == null) return head.val == pHead.val;
    boolean palindrome = isPalindrome(pHead.next);
    head = head.next;
    return palindrome && head.val == pHead.val;
}

从中间往两边比:快慢指针,速度1:2算出中间值

 public boolean isPalindrome(ListNode pHead) {
    if (pHead.next == null) return true;    // 一个数
    return toCompare(pHead, pHead.next.next) != null;
}
// 如果是,返回最后一个数
private  ListNode toCompare(ListNode left, ListNode next) {
    if (next == null) return left.next; //偶数
    if (next.next == null) return left.next.next;// 奇数
    ListNode right = toCompare(left.next, next.next.next);
    if (right == null) return null;
    if (left.next.val == right.val) 
        return right.next == null? right:right.next; // 返回最后一个数
    else return null;
}
全部评论

相关推荐

11-14 16:13
已编辑
重庆科技大学 测试工程师
Amazarashi66:不进帖子我都知道🐮❤️网什么含金量
点赞 评论 收藏
分享
1 收藏 评论
分享
牛客网
牛客企业服务