码迷,mamicode.com
首页 > 其他好文 > 详细

[LeetCode]Palindrome Linked List

时间:2015-11-29 10:43:00      阅读:171      评论:0      收藏:0      [点我收藏+]

标签:

反转后一半,然后判断,不过这样子会改变输入的数据,感觉不太好。也可以用一个栈,但是那样的话空间复杂度就不符合标准了。

/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode(int x) { val = x; }
 * }
 */
public class Solution {
    public boolean isPalindrome(ListNode head) {
        if (head == null || head.next == null) {
            return true;
        }
        int length = 0;
        ListNode p = head;
        while (p != null) {
            length ++;
            p = p.next;
        }
        p = head;
        ListNode pre = p;
        for (int i = 0; i < length / 2; i++) {
            pre = p;
            p = p.next;
        }
        if (length % 2 == 0) {
            pre.next = null;
            p = reverse(p);
        } else {
            pre.next = null;
            p = p.next;
            p = reverse(p);
        }
        while (head != null) {
            if (head.val != p.val) {
                return false;
            }
            head = head.next;
            p = p.next;
        }
        return true;
    }
    public ListNode reverse(ListNode head) {
        ListNode p2 = head;
        ListNode p1 = null;
        while (p2 != null) {
            ListNode tmp = p2;
            p2 = p2.next;
            tmp.next = p1;
            p1 = tmp;
        }
        return p1;
    }
}

 

[LeetCode]Palindrome Linked List

标签:

原文地址:http://www.cnblogs.com/vision-love-programming/p/5004377.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!