读书人

分治法动态规划及贪口算法感悟

发布时间: 2012-10-29 10:03:53 作者: rapoo

分治法,动态规划及贪心算法感悟

? ? ? 分治法,动态规划法,贪心算法这三者之间有类似之处,比如都需要将问题划分为一个个子问题,然后通过解决这些子问题来解决最终问题。但其实这三者之间的区别还是蛮大的。

?

1.分治法

?

? ? 分治法(divide-and-conquer):将原问题划分成n个规模较小而结构与原问题相似的子问题;递归地解决这些子问题,然后再合并其结果,就得到原问题的解。

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

?

分解—ivide):将原问题分解成一系列子问题;解决(conquer):递归地解各个子问题。若子问题足够小,则直接求解;合并(Combine):将子问题的结果合并成原问题的解。

?

?

? ?合并排序(merge sort)是一个典型分治法的例子。其对应的直观的操作如下:

?

读书人网 >编程

热点推荐