剑指 Offer II 026. 重排链表
创始人
2024-06-01 14:25:03
0

题目链接

剑指 Offer II 026. 重排链表 mid

题目描述

给定一个单链表 L的头节点 head,单链表 L表示为:

L0 → L1 → … → Ln-1 → Ln
请将其重新排列后变为:

L0 → Ln → L1 → Ln-1 → L2 → Ln-2 → …

不能只是单纯的改变节点内部的值,而是需要实际的进行节点交换。

示例 1:

在这里插入图片描述

输入: head = [1,2,3,4]
输出: [1,4,2,3]

示例 2:

在这里插入图片描述

输入: head = [1,2,3,4,5]
输出: [1,5,2,4,3]

提示:

  • 链表的长度范围为 [1,5∗104][1, 5 * 10^4][1,5∗104]
  • 1<=node.val<=10001 <= node.val <= 10001<=node.val<=1000

分析:栈

我们首先用 快慢指针 找到链表的中点,将中点后面一段的结点 塞到一个栈stack里(这样就可以把结点的顺序反过来,
栈顶元素就是最后一个结点
),接着再将栈中的结点弹出,插入到第一段中的位置(每两个节点中间插入一个)。

当链表结点数量是 奇数 时,slow指针需要往后移动一次才行。

在这里插入图片描述

当链表结点数量是 偶数 时。

在这里插入图片描述
时间复杂度:O(n)O(n)O(n)

代码:

/*** 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:void reorderList(ListNode* head) {ListNode * fast = head , *slow = head , *pre = nullptr;//快慢指针 求链表的中点while(fast && fast->next){pre = slow;fast = fast->next->next;slow = slow->next;}//根据结点数量是 奇数 还是 偶数分别处理,将链表分为两段if(fast){pre = slow;slow = slow->next;pre->next = nullptr;}else{pre->next = nullptr;}//用栈存储第二段的结点stack stk;while(slow){stk.push(slow->val);slow = slow->next;}//拼接到一起ListNode * cur = head;while(!stk.empty()){ListNode *nextNode = cur->next;int val = stk.top();stk.pop();ListNode *node = new ListNode(val);cur->next = node;node->next = nextNode;cur = nextNode;}}
};

相关内容

热门资讯

中证A500ETF摩根(560... 8月22日,截止午间收盘,中证A500ETF摩根(560530)涨1.19%,报1.106元,成交额...
A500ETF易方达(1593... 8月22日,截止午间收盘,A500ETF易方达(159361)涨1.28%,报1.104元,成交额1...
何小鹏斥资约2.5亿港元增持小... 每经记者|孙磊    每经编辑|裴健如 8月21日晚间,小鹏汽车发布公告称,公司联...
中证500ETF基金(1593... 8月22日,截止午间收盘,中证500ETF基金(159337)涨0.94%,报1.509元,成交额2...
中证A500ETF华安(159... 8月22日,截止午间收盘,中证A500ETF华安(159359)涨1.15%,报1.139元,成交额...
科创AIETF(588790)... 8月22日,截止午间收盘,科创AIETF(588790)涨4.83%,报0.760元,成交额6.98...
创业板50ETF嘉实(1593... 8月22日,截止午间收盘,创业板50ETF嘉实(159373)涨2.61%,报1.296元,成交额1...
港股异动丨航空股大幅走低 中国... 港股航空股大幅下跌,其中,中国国航跌近7%表现最弱,中国东方航空跌近5%,中国南方航空跌超3%,美兰...
电网设备ETF(159326)... 8月22日,截止午间收盘,电网设备ETF(159326)跌0.25%,报1.198元,成交额409....
红利ETF国企(530880)... 8月22日,截止午间收盘,红利ETF国企(530880)跌0.67%,报1.034元,成交额29.0...