【剑斩OFFER】算法的暴力美学——重排链表

一、题目描述

二、算法原理

思路:

1)使用快慢指针来找到链表的中间结点

2)把中间结点(不包含中间结点)后面的链表进行逆转

3)合并两个链表

三、代码实现

cpp 复制代码
/**
 * 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* slow = head,*fast = head;//快慢指针来找中间结点
        while(fast != nullptr && fast->next != nullptr)
        {
            slow = slow->next;
            fast = fast->next->next;
        }
        //此时 slow 就是中间结点,如果是偶数链表:1 2 3 4 此时 slow 指向的就是 3
        //逆转中间结点后面的链表
        ListNode* tmp = slow->next;
        slow->next = nullptr;
        slow = tmp;

        ListNode* prev = slow;
        if(prev == nullptr) return;//如果链表只有两个结点时,此时的 slow 是会越界的
        if(slow->next != nullptr)
        {
            ListNode* cur = prev->next;
            prev->next = nullptr;
            while(cur)
            {
                ListNode* tmp = cur->next;
                cur->next = prev;
                prev = cur;
                cur = tmp;
            }
        }
        //此时 prev 就是逆转后的表头
        //合并两个链表
        while(prev)
        {
            ListNode* tmp = head->next;
            ListNode* prevnext = prev->next;
            head->next = prev;
            prev->next = tmp;
            head = tmp;
            prev = prevnext;
        }
    }
};
相关推荐
zl_vslam2 小时前
SLAM中的非线性优-3D图优化之相对位姿Between Factor位姿图优化(十三)
人工智能·算法·计算机视觉·3d
Timmylyx05182 小时前
CF 新年赛 Goodbye 2025 题解
算法·codeforces·比赛日记
闻缺陷则喜何志丹2 小时前
【二分查找】P10091 [ROIR 2022 Day 2] 分数排序|普及+
c++·算法·二分查找
only-qi3 小时前
leetcode2. 两数相加
算法·leetcode
鲨莎分不晴3 小时前
拯救暗淡图像:深度解析直方图均衡化(原理、公式与计算)
人工智能·算法·机器学习
DuHz3 小时前
242-267 GHz双基地超外差雷达系统:面向精密太赫兹传感与成像的65nm CMOS实现——论文阅读
论文阅读·物联网·算法·信息与通信·毫米波雷达
AI科技星3 小时前
时空的固有脉动:波动方程 ∇²L = (1/c²) ∂²L/∂t² 的第一性原理推导、诠释与验证
数据结构·人工智能·算法·机器学习·重构
2401_841495644 小时前
【LeetCode刷题】寻找重复数
数据结构·python·算法·leetcode·链表·数组·重复数
罗技1234 小时前
Easysearch 集群监控实战(下):线程池、索引、查询、段合并性能指标详解
前端·javascript·算法