码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 【刷爆LeetCode】七月算法集训(29)分而治之


    题目来源于知识星球—英雄算法联盟,七月算法集训专题

    目录

    • 前言
    • 一、21.合并两个有序链表(简单)
      • 1.题目描述
      • 2.解题思路
      • 3.代码演示(C++)
      • 4.题目链接
    • 二、1985.找出数组中的第K大整数(中等)
      • 1.题目描述
      • 2.解题思路
      • 3.代码演示(C++)
      • 4.题目链接
    • 三、558.四叉树交集(中等)
      • 1.题目描述
      • 2.解题思路
      • 3.代码演示(C++)
      • 4.题目链接
    • 四、932.漂亮数组(中等)
      • 1.题目描述
      • 2.解题思路
      • 3.代码演示(C++)
      • 4.题目链接
    • 总结

    前言

    跟随英雄算法联盟博主—英雄哪里出来,每天完成相应的算法练习,一个月后,必定会有所成长!
    分治算法也很经典了,但是我当初学的时候可谓是一头雾水,迷迷糊糊的!
    今天的题和五月集训的题一样,算是回顾了!


    一、21.合并两个有序链表(简单)

    1.题目描述

    https://img-blog.csdnimg.cn/9228089a7fce408c9bef9d20774f271b.jpeg =500x

    2.解题思路

    先考虑存在链表为空链表的情况,如果有其中一个链表为空链表,则直接返回
    另一个非空链表。当两个链表都不为空时,用递归方法取值较小的放在前面,
    next指针继续计算。
    
    • 1
    • 2
    • 3

    3.代码演示(C++)

    class Solution 
    {
    public:
        ListNode* mergeTwoLists(ListNode* list1, ListNode* list2) 
        {
            if(list1 == nullptr) 
            {
                return list2;
            }
            else if(list2 == nullptr) 
            {
                return list1;
            }
            ListNode *t = new ListNode();
            if(list1->val < list2->val)
            {
                t->val = list1->val;
                t->next = mergeTwoLists(list1->next, list2);
            }
            else 
            {
                t->val = list2->val;
                t->next = mergeTwoLists(list1, list2->next);
            }
            return t;
        }
    };
    
    • 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
    • 27

    4.题目链接

    题目传送门


    二、1985.找出数组中的第K大整数(中等)

    1.题目描述

    https://img-blog.csdnimg.cn/2d4646142b14485bbfd589dec0946081.jpeg =500x

    2.解题思路

    这道题的本质为将字符串数组进行排序,然后找到第K大的整数,首先将
    字符串长的放到前面,如果字符串长度相同,那么进行降序排列,最后
    返回第k大的元素。
    
    • 1
    • 2
    • 3

    3.代码演示(C++)

    class Solution 
    {
    public:
        static bool cmp (string &a, string &b)
        {
            if(a.size()==b.size()) return  a>b;
            return a.size() > b.size();
        }
        string kthLargestNumber(vector<string>& nums, int k) 
        {
            sort(nums.begin(), nums.end(),cmp);
            return  nums[k-1];
        }
    };
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14

    4.题目链接

    题目传送门


    三、558.四叉树交集(中等)

    1.题目描述

    https://img-blog.csdnimg.cn/43544a780b9f4ca1b4642362deeb23da.jpeg =500x

    2.解题思路

    以后再来刷
    
    • 1

    3.代码演示(C++)

    
    
    • 1

    4.题目链接

    题目传送门


    四、932.漂亮数组(中等)

    1.题目描述

    https://img-blog.csdnimg.cn/173198a222ce48e0aa327999697ed022.jpeg =500x

    2.解题思路

    等式左边是偶数,那么右边为奇数可以保证永不相等。
    可以将A[i]映射为奇数,A[j]映射为偶数。问题转化为,左区间映射为奇数,有区间映射为偶数,
    由于漂亮数组经过k*a+b的变化后,仍然是漂亮数组。
    因此,可以分解成若干子问题,用分治求解。
    
    • 1
    • 2
    • 3
    • 4

    3.代码演示(C++)

    class Solution 
    {
    public:
        vector<int> beautifulArray(int n)
        {
            vector<int> ans;
            if(n==1)
            {
                ans.push_back(1);
                return ans;
            }
            int odd_num=(n+1)/2;
            int even_num=n/2;
            vector<int> left_arry=beautifulArray(odd_num);
            vector<int> right_arry=beautifulArray(even_num);
            //将左侧数组映射为奇数
            for(auto &val:left_arry)
            {
                ans.push_back(val*2-1);
            }
            //将右侧数组映射为偶数
            for(auto &val:right_arry)
            {
                ans.push_back(val*2);
            }
            return ans;
        }
    };
    
    • 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
    • 27
    • 28

    4.题目链接

    题目传送门


    总结

    每天跟随英雄哥学习相关的算法,一个月会收获很多,如果你想了解更多关于知识星球的内容,欢迎联系我!

  • 相关阅读:
    谷歌Colab配置 运行python项目 教程
    亏损扩大/毛利偏低,北斗智联与「智能座舱第一阵营」的不等号
    2023CCPC重庆经验小结
    centos7安装php
    21天学习挑战赛--猜密码
    SUBMIT指定用户名错误
    美容院如何体现差异化服务?
    .NET面试题2
    docker pull、docker load、docker run使用方法
    Oracle的listagg的用法和例子
  • 原文地址:https://blog.csdn.net/LAdestiny/article/details/126067580
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号