Leetcode算法基础篇-分治算法

分治算法

「分而治之」,就是把一个复杂的问题分成两个或更多的相同或相似的子问题,直到最后子问题可以简单的直接求解,原问题的解即子问题的解的合并。

我们发现分治算法的思想和递归相似,实际上 递归算法∈分治算法

解题步骤:

  1. 分解:把问题分解为子问题
  2. 求解:递归求解各个子问题
  3. 合并:将子问题解合并为原问题到解

练习题

912. 排序数组

思路

  • 考虑归并排序
  • 实现

代码

cpp 复制代码
class Solution {
public:
    void mergeSort(vector<int>& nums, int l, int r) {
        if(l >= r) return;
        int m = (l + r) / 2;
        mergeSort(nums, l, m);
        mergeSort(nums, m + 1, r);
        int i = l, j = m + 1;
        vector<int> ans;
        while(i <= m && j <= r) {
            int val = nums[i] <= nums[j] ? nums[i++] : nums[j++];
            ans.push_back(val);
        }

        while(i <= m) ans.push_back(nums[i++]);
        while(j <= r) ans.push_back(nums[j++]);

        for(int i = l; i <= r; i++) {
            nums[i] = ans[i - l];
        }
    }

    vector<int> sortArray(vector<int>& nums) {
        int sz = nums.size();
        if(sz <= 1) return nums;

        mergeSort(nums, 0, sz - 1);

        return nums;
    }
};

704. 二分查找

思路

  • 二分查找模板题
  • 实现

代码

cpp 复制代码
class Solution {
public:
    int search(vector<int>& nums, int target) {
        int sz = nums.size();
        int l = 0, r = sz - 1;
        while(l < r) {
            int m = l + (r - l) / 2;
            if(nums[m] == target) return m;
            else if(nums[m] > target) r--;
            else l++;
        }
        return nums[l] == target ? l : -1;
    }
};
相关推荐
黄敬峰2 小时前
深入理解算法核心:从递归思想、数组扁平化到快速排序
算法
得物技术4 小时前
从狂野代码到按目标生产:得物推荐 AI Harness 的工程化实践|AICon 演讲整理
人工智能·算法·架构
AI小老六7 小时前
SkillOpt 架构拆解:把 Skill 文本当参数,用执行轨迹训练 Agent
后端·算法·ai编程
胡萝卜术8 小时前
从“分数打架”到“排名投票”:为什么你的ChatBI必须用RRF?
算法·设计模式·面试
Asize8 小时前
初识DFS 与 BFS:递归、队列与图遍历
算法
罗西的思考1 天前
机器人 / 强化学习】HIL-SERL:人类在环驱动的具身智能进化框架
人工智能·算法·机器学习
CSharp精选营1 天前
关系型 vs 非关系型:从原理到选型,一文搞定数据库核心分类
数据结构·nosql·关系型数据库·非关系型数据库·技术选型
美团技术团队1 天前
LongCat 开源 VitaBench 2.0:长期动态智能体基准新标杆
人工智能·算法
To_OC2 天前
LC 207 课程表:刚学图论那会儿,我连这是拓扑排序都没看出来
javascript·算法·leetcode
To_OC2 天前
LC 208 实现 Trie 前缀树:曾被名字劝退,写完发现是送分题
javascript·算法·leetcode