给你一个单链表的头节点 head
,请你判断该链表是否为
回文链表。如果是,返回 true
;否则,返回 false
。
一:
复杂度:n n
java
puclic boolean isPalindrome(ListNode head){
// 使用集合而不是array,可以避免创建数组前要先获取链表的长度问题
List<Integer> list = new ArrayList<>();
while(head != null){
list.add(head.val);
head = head.next;
}
int l = 0, r = list.size() - 1;
while(l < r){
if(list.get(l++) != list.get(r--)) return false;
}
return true;
}
二:
将链表的后半部分反转,判断前后部分是否相等
复杂度:n 1
java
class Solution {
public boolean isPalindrome(ListNode head) {
//
int len = 0;
ListNode pre = head;
while(pre != null){
len++;
pre = pre.next;
}
// if(len != 1 && len % 2 == 1) return false;
pre = head;
for(int i = 0; i < len / 2; i++){
pre = pre.next;
}
ListNode pre0 = pre, next = pre.next;
pre0.next = null;
while(next != null){
pre0 = next;
next = pre0.next;
pre0.next = pre;
pre = pre0;
}
while(pre != null){
if(head.val != pre.val) return false;
head = head.next;
pre = pre.next;
}
return true;
}
}