剑指 Offer II 027. 回文链表 ●
描述
给定一个链表的 头节点 head ,请判断其是否为回文链表。
如果一个链表是回文,那么链表节点序列从前往后看和从后往前看是相同的。
示例
输入: head = [1,2,3,3,2,1]
输出: true
题解
1. 模拟
遍历链表节点后,首尾判断数值是否相等。
/**
* Definition for singly-linked list.
* struct ListNode {
* int val;
* ListNode *next;
* ListNode() : val(0), next(nullptr) {}
* ListNode(int x) : val(x), next(nullptr) {}
* ListNode(int x, ListNode *next) : val(x), next(next) {}
* };
*/
class Solution {
public:
bool isPalindrome(ListNode* head) {
ListNode* curr = head;
vector<int> nums;
while(curr != nullptr){
nums.emplace_back(curr->val);
curr = curr->next;
}
int n = nums.size();
for(int i = 0; i <= n / 2; ++i){
if(nums[i] != nums[n-1-i]) return false;
}
return true;
}
};