美文网首页
分治法的简单介绍和实现

分治法的简单介绍和实现

作者: BestbpF | 来源:发表于2018-08-13 16:21 被阅读1次

一、介绍

分治法可以通俗的解释为:把一片领土分解,分解为若干块小部分,然后一块块地占领征服,被分解的可以是不同的政治派别或是其他什么,然后让他们彼此异化。

分治法的精髓:

  • 分--将问题分解为规模更小的子问题;
  • 治--将这些规模更小的子问题逐个击破;
  • 合--将已解决的子问题合并,最终得出“母”问题的解;

二、步骤

  • 分解:将原问题分解为若干个规模较小,相互独立,与原问题形式相同的子问题;
  • 解决:若子问题规模较小而容易被解决则直接解,否则递归地解各个子问题;
  • 合并:将各个子问题的解合并为原问题的解。

三、应用

给定数组,求数组中的最大值

思路:将数组分为若干个子集,求出最小规模子集内的最大值,然后各个子集之间求最大值,这样子集逐渐变大合并,最后得出答案。

    public static int getMax(int[] nums, int left, int right){
        if(left == right){
        //此处为规模最小子集,直接求解
            return nums[left];
        }

        //此处为递归求解子问题
        int center = (left + right)/2;
        int leftMax = getMax(nums, left, center);
        int rightMax = getMax(nums, center + 1, right);
        //子问题结果合并并返回给上一层
        return leftMax > rightMax ? leftMax : rightMax;
    }

相关文章

  • 分治法的简单介绍和实现

    一、介绍 分治法可以通俗的解释为:把一片领土分解,分解为若干块小部分,然后一块块地占领征服,被分解的可以是不同的政...

  • Java基于分治算法实现的棋盘覆盖问题示例

    Java基于分治算法实现的棋盘覆盖问题示例 本文主要介绍了ava基于分治算法实现的棋盘覆盖问题,简单描述了棋盘覆盖...

  • 所有实验

    实验一 实验目的与要求:理解分治法的基本思想和设计方法。 实验题目: 1.实现基于分治法的归并排序算法. 2.实现...

  • 09《算法入门教程》分治算法

    1. 前言 本节内容是分治算法系列之一:分治算法的介绍,主要介绍了分治算法的定义及基本思想和实现策略,然后我们介绍...

  • python实现归并排序(MergeSort)

    python实现【归并排序】(MergeSort) 算法原理及介绍 归并排序的核心原理是采用分治法(Divide ...

  • 分治策略

    求解递归式方法 最大子数组问题 分治策略 分治法流程 伪代码 C++实现 线性解 流程 代入法求解递归式 递归树法...

  • 分治法(Divide-and-Conquer Algorithm

    上次给大家带来了分治法的基本介绍和基本思想,今天我们继续来看分治算法的几个经典例子。 **01 ** 快速排序 1...

  • 3.1 分治法介绍及关键点解析

    Chapter3: 更好的查找与排序算法 1. 分治法介绍及关键点解析 什么是分治法 基本思想 将原问题划分为若干...

  • Divide and Conquer

    算法之 分治法 Divide and Conquer 分治法: 分治法的设计思想是:将一个难以直接解决的大问题,分...

  • 归并排序

    1、分治法 归并排序是完全遵循分治策略的排序算法。什么是分治法? 分治法,即将原问题分解为几个规模较小的子问题,递...

网友评论

      本文标题:分治法的简单介绍和实现

      本文链接:https://www.haomeiwen.com/subject/aaeubftx.html