234 回文链表

 

 方法一:快慢指针加反转链表

 

22 23 24是讲  :直到快指针为null的时候,这个时候反转链表。 

         1-016-(LeetCode-234) 回文链表_哔哩哔哩_bilibili

找到中间节点之后反转。 快指针再从头开始,慢指针也是从头,一个一个对比。

方法二:将值复制到数组中后用双指针法

确定数组列表是否回文很简单,我们可以使用双指针法来比较两端的元素,并向中间移动。一个指针从起点向中间移动,另一个指针从终点向中间移动。这需要 O(n)O(n) 的时间,因为访问每个元素的时间是 O(1)O(1),而有 nn 个元素要访问。

然而同样的方法在链表上操作并不简单,因为不论是正向访问还是反向访问都不是 O(1)。而将链表的值复制到数组列表中是 O(n),因此最简单的方法就是将链表的值复制到数组列表中,再使用双指针法判断。

力扣

 还有个方法是递归,但是不是特别清晰明白

### 判断回文链表的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]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值