title | toc | date | tags | top |
---|---|---|---|---|
Divide and Conquer |
true |
2017-10-30 |
3 |
In divide and conquer(分治法), we solve a problem recursively, applying three steps at each level of the recursion[1]:
-
Divide the problem into a number of subproblems that are smaller instances of the same problem.
-
Conquer the subproblems by solving them recursively. If the subproblem sizes are small enough, however, just solve the subproblems in a straightforward manner.
-
Combine the solutions to the subproblems into the solution for the original problem.
分治法的设计思想是:
- 分 – 将问题分解为规模更小的子问题;
- 治 – 递归地解决子问题;
- 合 – 将子问题的解合并成原问题的解;
Recurrences (递归表达式) go hand in hand with the divide-and-conquer paradigm. A recurrence is an equation or inequality that describes a function in terms of its value on smaller inputs[1].
例如, 归并排序的最差运行时间$T(n)$用递归表达式表达为
利用分治法解决的经典问题:
- 二分搜索
- 大整数的乘法
- Strassen矩阵乘法
- 归并排序
- 快速排序
MergeSort (归并排序) divides the list
Pseudocode:
MergeSort Input: List L of ``orderable” elements
Modifies: List L is sorted in-place in ascending order
Output: None
If n>1
copy L[0..⎣n/2⎦-1] to A[0..⎣n/2⎦-1];
copy L[⎣n/2⎦..n-1] to B[0.. ⎡n/2⎤-1];
MergeSort(A[0..⎣n/2⎦-1]);
MergeSort(B[0..⎡n/2⎤-1]);
Merge(A,B,L);
Let
Then, we have the recurrence::
- 算法导论(第三版英文版)
- Algorithm thinking on Coursera