leetcode-148-Sort List

本文探讨了利用归并排序解决链表问题的方法,通过快慢指针技术寻找链表中点,实现链表的有效分割。文章详细解释了归并过程中元素交换的重要性,避免直接赋值导致的问题,并强调了递归调用在归并排序中的关键作用。

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

It use merge sort to deal with the problem:

  1. Use fast slow pointers to traverse the list and find the mid-point at once(move 1 step for slow, 2 step for fast)
  2. before merge, break the slow connect, merge it.
  3. in merge, do not directly assign selected element to merge, use swap() to swap the head of left and right, then directly assign left to merge. SO after that all elements in right will larger than left.(think about we need to actually swap the element not value)

Error:
5. Do not trully understand what is merge sort: 1) merge it until single elements, 2) merge it.
So, we need to call the function recursively with left list and right list.
6. When meet single element, return directly.

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值