leetcode || 143、Reorder List

本文介绍了一种单链表的重新排序算法,通过使用栈来辅助操作,实现了将链表尾部节点依次插入头部节点之后的过程。此算法在不改变节点值的前提下完成了链表的重排。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

problem:

Given a singly linked list LL0L1→…→Ln-1Ln,
reorder it to: L0LnL1Ln-1L2Ln-2→…

You must do this in-place without altering the nodes' values.

For example,
Given {1,2,3,4}, reorder it to {1,4,2,3}.

Hide Tags
  Linked List
题意:对单链表重新排序,依次将尾节点插入到头节点的后面。

thinking:

(1)由于单链表只有一个next指针,所以需要借助stack存储节点指针。

(2)每次将stack的顶部节点插入到单链表的头结点的后面,修改相关指针,头指针往后遍历

(3)直到头指针等于stack顶部元素(单链表节点总素为奇数)或者,头指针的下一个节点为stack的顶部元素(总素为偶数),停止遍历

,将最后一个节点next指针置空

code:时间复杂度O(n)

class Solution {
  public:
      void reorderList(ListNode* head) {
          stack<ListNode *> _stack;
          ListNode *tmp=head;
          while(tmp!=NULL)
          {
              _stack.push(tmp);
              tmp=tmp->next;
          }
          if(_stack.size()<3)
              return;
          ListNode *p= head;
          ListNode *q=_stack.top();
          while(p!=q && p->next!=q)
          {
              _stack.pop();
              ListNode *p_next=p->next;
              p->next=q;
              q->next=p_next;
              p=p_next;
              q=_stack.top();
          }
          q->next=NULL;
      }
  };

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值