码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • LeetCode 0143. 重排链表


    【LetMeFly】143.重排链表

    力扣题目链接:https://leetcode.cn/problems/reorder-list/

    给定一个单链表 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 <= node.val <= 1000

    方法一:哈希表

    遍历链表,将链表节点存入哈希表中,映射关系为<[第几个节点, 节点]>(其实这里使用数组也可以,虽然复杂度相同,但是数组的实际开销还是要小一些)

    然后,用两个指针 l l l和 r r r,分别指向前面该处理的节点和后面该处理的节点

    当前指针超过后指针时,退出循环。

    注意事项:

    1. 用head遍历完链表后,head已经不再指向头节点,记得将head归位
    2. 记得将链表的最后一个节点的next置空
    • 时间复杂度 O ( n ) O(n) O(n),其中 n n n是链表节点个数
    • 空间复杂度 O ( n ) O(n) O(n)

    AC代码

    C++

    class Solution {
    public:
        void reorderList(ListNode* head) {
            unordered_map<int, ListNode*> ma;
            int cnt = 0;
            while (head) {
                ma[cnt++] = head;
                head = head->next;
            }
            head = ma[0];  // head归位
            int l = 1, r = cnt - 1;  // 待指定
            bool front = false;
            while (l <= r) {
                if (front) {
                    head->next = ma[l++];
                    front = false;
                }
                else {
                    head->next = ma[r--];
                    front = true;
                }
                head = head->next;
            }
            head->next = nullptr;  // 最后一个节点的next置空
        }
    };
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26

    同步发文于CSDN,原创不易,转载请附上原文链接哦~
    Tisfy:https://letmefly.blog.csdn.net/article/details/126031446

  • 相关阅读:
    uniCloud开发公众号:五、开通/配置/初始化uniPush2.0
    查看Java程序的进程编号
    Cockpit -- 一个通过浏览器监控和管理多台Linux服务器的强大工具
    华为数通方向HCIP-DataCom H12-831题库(单选题:61-80)
    自定义样式与模板
    如何快速从 ETL 到 ELT?火山引擎 ByteHouse 做了这三件事
    如何提取视频中的音频转为mp3
    Java分库分表/读写分离
    01、MySQL-------性能优化
    AbstractApplicationContext抽象类解读
  • 原文地址:https://blog.csdn.net/Tisfy/article/details/126031446
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号