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;
    }
};
相关推荐
闻缺陷则喜何志丹1 分钟前
【强连通分量 缩点 拓扑排序】P3387 【模板】缩点|普及+
c++·算法·拓扑排序·洛谷·强连通分量·缩点
钮钴禄·爱因斯晨1 分钟前
Java 面向对象进阶之多态:从概念到实践的深度解析
java·开发语言·数据结构
机器学习之心34 分钟前
机器学习用于算法交易(Matlab实现)
算法·机器学习·matlab
AL流云。35 分钟前
【优选算法】C++滑动窗口
数据结构·c++·算法
qq_429879672 小时前
省略号和可变参数模板
开发语言·c++·算法
飞川撸码3 小时前
【LeetCode 热题100】网格路径类 DP 系列题:不同路径 & 最小路径和(力扣62 / 64 )(Go语言版)
算法·leetcode·golang·动态规划
Neil今天也要学习3 小时前
永磁同步电机参数辨识算法--IPMSM拓展卡尔曼滤波全参数辨识
单片机·嵌入式硬件·算法
yzx9910134 小时前
基于 Q-Learning 算法和 CNN 的强化学习实现方案
人工智能·算法·cnn
亮亮爱刷题4 小时前
算法练习-回溯
算法
眼镜哥(with glasses)5 小时前
蓝桥杯 国赛2024python(b组)题目(1-3)
数据结构·算法·蓝桥杯