[编程题]回文链表

回文链表

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

相关推荐

湫湫湫不会java:先投着吧,大概率找不到实习,没实习的时候再加个项目,然后把个人评价和荣誉奖项删了,赶紧成为八股战神吧,没实习没学历,秋招机会估计不多,把握机会。或者说秋招时间去冲实习,春招冲offer,但是压力会比较大
点赞 评论 收藏
分享
流浪的神仙:无恶意,算法一般好像都得9硕才能干算法太卷啦
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务