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;
    }
};
相关推荐
AitTech1 小时前
掌握C#中的动态规划技术
算法·c#·动态规划
新知图书1 小时前
Rust 运算符快速了解
算法
笨笨D幸福1 小时前
Rust 全局变量的最佳实践 lazy_static/OnceLock/Mutex/RwLock
开发语言·算法·rust
乘风破浪的咸鱼君2 小时前
2024/9/21 leetcode 19题 24题
数据结构·算法·leetcode
小松学前端3 小时前
第四章 4.2 时间复杂度
java·数据结构·算法·排序算法
Long long 523 小时前
常见排序详解
数据结构·算法·排序算法
小周的C语言学习笔记3 小时前
鹏哥C语言49---第5次作业:选择语句 if 和 switch
c语言·开发语言·c++·算法
李妖妖的拯救者3 小时前
C语言小tip之动态内存常见错误
c语言·c++·算法
深鱼~4 小时前
【二分算法】模板总结
算法