分治法——思想到使用——归并排序、快速排序

本文介绍了分治法的基本概念及其在归并排序和快速排序中的应用。分治法通过分解、解决和合并三个步骤来解决复杂问题。归并排序采用分治策略,通过递归分解数组再合并实现排序;快速排序同样利用分治法,选取基准进行分区操作完成排序。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

    分而治之。方法一般是利用递归。分治和递归一般同时出现。

    分治模式在第一层递归上都有三个步骤:

          分解(Divide):将原问题分解成一系列子问题;

          解决(Conquer):递归地解决名子问题。若子问题足够小,则直接求解;

          合并(Combine):将子问题的结果合并成原问题的解。

分治法所能解决的问题一般具有以下几个特征:  1) 该问题的规模缩小到一定的程度就可以容易地解决  2) 该问题可以分解为若干个规模较小的相同问题,即该问题具有最优子结构性质。  3) 利用该问题分解出的子问题的解可以合并为该问题的解;  4) 该问题所分解出的各个子问题是相互独立的,即子问题之间不包含公共的子子问题。  上述的第一条特征是绝大多数问题都可以满足的,因为问题的计算复杂性一般是随着问题规模的增加而增加;第二条特征是应用分治法的前提它也是大多数问题可以满足的,此特征反映了递归思想的应用;第三条特征是关键,能否利用分治法完全取决于问题是否具有第三条特征,如果具备了第一条和第二条特征,而不具备第三条特征,则可以考虑用贪心法或动态规划法。第四条特征涉及到分治法的效率,如果各子问题是不独立的则分治法要做许多不必要的工作,重复地解公共的子问题,此时虽然可用分治法,但一般用动态规划法较好。

 

归并排序伪代码:

 

 

快速排序伪代码:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值