算法设计与分析——分治法

通俗的来说:就是把一个问题分解成为大小相同的k个子问题是比较不错的。(事实上这种使子问题大致相同的做法是一种自平衡子问题的思想)。

定义:

分治法的思想是将一个规模为n的问题分解为k个规模较小的子问题,这些子问题互相独立且与原问题相同。

解决方法:

我们可以递归的解决这些子问题,然后将这些小的子问题和原问题合并,进而各个击破,达到解决整个原问题的目的!
分治算法分解为多少个子问题比较的合适呢?
其实这个问题前人也是经过了很多的经验才发现了在使用分治法设计算法时,最好使子问题的规模大致相同,即讲一个子问题分解为大小相同的k个子问题比较的合适。这种使子问题的 规模大致相同的做法是一种自平衡的思想。并且使用分治法的算法一般是递归的算法。

分治法比较常见的一种使用方式(二分搜索算法)

下面是我总结的二分题目链接:

2020 CCPC Wannafly Winter Camp Day1 F 乘法

Codeforces 1323 D. Present

Codeforces 1238 B. Kill 'Em All

Codeforces 1324 D. Pair of Topics

Codeforces D. Xenia and Colorful Gems

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值