234. 回文链表

https://leetcode-cn.com/problems/palindrome-linked-list/

难度简单1087

给你一个单链表的头节点 head ,请你判断该链表是否为回文链表。如果是,返回 true ;否则,返回 false 。

示例 1:

输入:head = [1,2,2,1]
输出:true

示例 2:

输入:head = [1,2]
输出:false

提示:

  • 链表中节点数目在范围[1, 105] 内
  • 0 <= Node.val <= 9

进阶:你能否用 O(n) 时间复杂度和 O(1) 空间复杂度解决此题?

通过次数293,160提交次数595,792

/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode() {}
 *     ListNode(int val) { this.val = val; }
 *     ListNode(int val, ListNode next) { this.val = val; this.next = next; }
 * }
 */
class Solution {
    public boolean isPalindrome(ListNode head) {
        List<Integer> num = new ArrayList<Integer>();
        while(head!=null)
        {
            num.add(head.val);
            head = head.next;
        }
        for(int i=0,j=num.size()-1;i<j;i++,j--)
        {
            if(num.get(i)!=num.get(j)) return false;
        }
        return true;
    }
}

 

 

### 判断回文链表的C++实现 为了判断一个单链表是否为回文链表,可以采用双端队列法或快慢指针加反转部分链表的方法。这里提供一种较为高效的算法——通过快慢指针找到链表中点并反转前半部分链表来进行比较。 #### 方法概述 利用两个速度不同的指针遍历整个列表:一个是每次移动一步(slow),另一个则是每两次才前进一次(fast)。当 fast 达到终点时,slow 正好位于中间位置。接着将 slow 后面的部分进行翻转并与前面未改变顺序的一半做对比即可得出结论[^1]。 下面是具体的 C++ 实现: ```cpp #include <iostream> using namespace std; // 定义链表节点结构体 struct ListNode { int val; ListNode *next; ListNode(int x) : val(x), next(nullptr) {} }; bool isPalindrome(ListNode* head) { if (!head || !head->next) return true; // 空链表或只有一个元素的情况 ListNode *slow = head, *fast = head; stack<int> stk; while (fast != nullptr && fast->next != nullptr){ stk.push(slow->val); slow = slow->next; fast = fast->next->next; } // 如果长度为奇数,则跳过中心结点 if(fast!=nullptr){ slow=slow->next; } while (slow != nullptr){ int topVal = stk.top(); stk.pop(); if(topVal != slow -> val){ return false; }else{ slow = slow -> next; } } return true; } ``` 此段程序首先定义了一个 `ListNode` 类型用于表示链表中的每一个节点。函数 `isPalindrome()` 接受指向链表头部的指针作为参数,并返回布尔值指示该链表是否构成回文序列。其中运用到了栈的数据结构来保存前一半链表的信息以便后续匹配验证[^3]。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值