[编程题]回文链表

回文链表

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;
}
全部评论

相关推荐

09-29 11:19
门头沟学院 Java
点赞 评论 收藏
分享
勤奋努力的椰子这就开摆:美团骑手在美团工作没毛病
投递美团等公司10个岗位
点赞 评论 收藏
分享
1 收藏 评论
分享
牛客网
牛客企业服务