【算法刷题】leetcode reorder-list

本文介绍了一种在不改变节点值的情况下,对单链表进行重新排序的方法。具体实现包括找到链表中点、反转后半部分链表,然后交替合并前半部分链表与反转后的后半部分链表。

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

Given a singly linked list LL 0L 1→…→L n-1L n,
reorder it to: L 0L n L 1L n-1L 2L n-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}.

	void reorderList(ListNode *head) {
		
		if (head == nullptr)
			return;
		//fast and low point to find the middle pos 
		ListNode* slow = head;
		ListNode* fast = head;

		if (fast->next == nullptr)
			return;

		fast = fast->next;

		if (fast->next == nullptr)
			return;
		
		fast = fast->next;

		while (fast->next != nullptr)
		{
			fast = fast->next;
			
			if (fast->next != nullptr)
				fast = fast->next;

			slow = slow->next;
		}

		//split and reverse

		ListNode* after = slow->next;
		slow->next = nullptr;
		ListNode* pre = nullptr;
		while (after !=nullptr)
		{
			ListNode* temp = after->next;
			if (temp == nullptr)
				fast = after;

			after->next = pre;
			pre = after;
			after = temp;

		} 
		//merge fast and slow, slow is first

		slow = head;
		while (slow != nullptr && fast != nullptr)
		{
			pre = fast;
			fast = fast->next;
			pre->next = slow->next;
			slow->next = pre;
			slow = pre->next;			
		}
        //only fast list can more than one
        pre->next = fast;



	}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值