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;
    }
};
相关推荐
山登绝顶我为峰 3(^v^)314 分钟前
如何录制带备注的演示文稿(LaTex Beamer + Pympress)
c++·线性代数·算法·计算机·密码学·音视频·latex
Two_brushes.1 小时前
【算法】宽度优先遍历BFS
算法·leetcode·哈希算法·宽度优先
森焱森3 小时前
水下航行器外形分类详解
c语言·单片机·算法·架构·无人机
QuantumStack5 小时前
【C++ 真题】P1104 生日
开发语言·c++·算法
写个博客6 小时前
暑假算法日记第一天
算法
绿皮的猪猪侠6 小时前
算法笔记上机训练实战指南刷题
笔记·算法·pta·上机·浙大
hie988947 小时前
MATLAB锂离子电池伪二维(P2D)模型实现
人工智能·算法·matlab
杰克尼7 小时前
BM5 合并k个已排序的链表
数据结构·算法·链表
.30-06Springfield7 小时前
决策树(Decision tree)算法详解(ID3、C4.5、CART)
人工智能·python·算法·决策树·机器学习
我不是哆啦A梦8 小时前
破解风电运维“百模大战”困局,机械版ChatGPT诞生?
运维·人工智能·python·算法·chatgpt