DIVIDE-AND-CONQUER ALGORITHMS proceed as follows.
- Divide
- the input problem into sub-problems.
- Conquer
- on the sub-problems by solving them directly if they are small
enough or proceed recursively.
- Combine
- the solutions of the sub-problems to obtain the solution of the
input problem.
EQUATION SATISFIED BY
MATHEND000#.
Assume that the size of the input problem increases with an integer
.
Let
be the time complexity of a divide-and-conquer algorithm
to solve this problem.
Then
satisfies an equation of the form:
data:image/s3,"s3://crabby-images/075bb/075bbb50f151bce8198351b8e9a045d7acfd549d" alt="$\displaystyle T(n) = a \, T(n/b) + f(n).$" |
(14) |
where
is the cost of the combine-part,
is the
number of recursively calls and
with
is the size of a sub-problem.
LABELED TREE ASSOCIATED WITH THE EQUATION.
Assume
is a power of
, say
To solve this equation we can associate a labeled tree
to it
as follows.
- If
, then
is reduced to a single leaf by labeled
.
- If
, then the root of
is labeled
by
and
possesses
labeled sub-trees all equal to
.
The labeled tree
associated with
has height
.
Moreover the sum of its labels is
.
LET US GIVE TWO EXAMPLES.
- Consider the relation:
data:image/s3,"s3://crabby-images/ad3f4/ad3f4dd24fddfcc2622cbfd917ff5f6857008f6f" alt="$\displaystyle T(n) = 2 \, T(n/2) + n^2.$" |
(15) |
We obtain:
data:image/s3,"s3://crabby-images/0e3d5/0e3d5d92926bae3273df8a0d5d6cf7f86e6fa5f9" alt="$\displaystyle T(n) = n^2 + \frac{n^2}{2} + \frac{n^2}{4} + \frac{n^2}{8} + \cdots + \frac{n^2}{2^p} + n\, T(1).$" |
(16) |
Hence we have:
data:image/s3,"s3://crabby-images/f7be6/f7be695ea362f039a10baa3bafba434e6d2e7913" alt="$\displaystyle T(n) \in {\Theta}(n^2).$" |
(17) |
- Consider the relation:
data:image/s3,"s3://crabby-images/434ef/434efe70a3f56a3f28339442476ce317386d3179" alt="$\displaystyle T(n) = 3 T(n/3) + n.$" |
(18) |
We obtain:
data:image/s3,"s3://crabby-images/90e76/90e76576d2e35bbb270385bc9ef577892258ebf4" alt="$\displaystyle T(n) \in {\Theta}({\log}_3(n) n).$" |
(19) |
A FORMULA TO ESTIMATE
MATHEND000#.
Let
be an integer and let
be functions
such that
-
and
.
- If
then
Then for
we have
- if
then
data:image/s3,"s3://crabby-images/115fd/115fd26814bcaa7eb4b15f2cf541e51a622dbd83" alt="$\displaystyle T(n) \leq (2 - 2/n) \, S(n) + T(1) \ \in \ {\cal O}(S(n)),$" |
(20) |
- if
then
data:image/s3,"s3://crabby-images/45301/453016dcd3d33f1198ad26b486fb5d1f8458f06b" alt="$\displaystyle T(n) \leq S(n) \, {{\log}_2}(n) + T(1) \, n \ \in \ {\cal O}({{\log}_2}(n) \, S(n)),$" |
(21) |
- if
then
data:image/s3,"s3://crabby-images/c84ae/c84aeb0e700b3f0699ae613703197bdb5804538f" alt="$\displaystyle T(n) \leq \frac{2}{a-2} \left( n^{{{\log}_2}(a) - 1} - 1 \right) ...
...n) + T(1) \, n^{{{\log}_2}(a)} \ \in \ {\cal O}(S(n) \, n^{{{\log}_2}(a) - 1}).$" |
(22) |
Indeed
data:image/s3,"s3://crabby-images/0fce0/0fce032fd0ab793cc135b50345206a3e0d1e0b78" alt="\begin{displaymath}\begin{array}{rcl} T(2^p) & \leq & a \, T(2^{p-1}) + S(2^p) \...
..., T(1) + {\Sigma}_{j=0}^{j=p-1} \ a^j \, S(2^{p-j}) \end{array}\end{displaymath}" |
(23) |
Moreover
data:image/s3,"s3://crabby-images/88bcc/88bcc21626b9b6c52ea112f09a3cbce55df31550" alt="\begin{displaymath}\begin{array}{rcl} S(2^p) & \geq & 2 \, S(2^{p-1}) \\ S(2^p) ...
...vdots & \vdots \\ S(2^p) & \geq & 2^j \, S(2^{p-j}) \end{array}\end{displaymath}" |
(24) |
Thus
data:image/s3,"s3://crabby-images/6ea17/6ea17b4552da9b077293f8bb0a8b7242bc19b1a6" alt="$\displaystyle {\Sigma}_{j=0}^{j=p-1} \ a^j \, S(2^{p-j}) \ \leq \ S(2^p) \, {\Sigma}_{j=0}^{j=p-1} \ {\left( \frac{a}{2} \right)}^j.$" |
(25) |
Hence
data:image/s3,"s3://crabby-images/dbd02/dbd025e1294ee0c80e7cbf17ef7c003089b9d2a5" alt="$\displaystyle T(2^p) \ \leq \ a^p \, T(1) + S(2^p) \, {\Sigma}_{j=0}^{j=p-1} \ {\left( \frac{a}{2} \right)}^j.$" |
(26) |
For
we obtain
data:image/s3,"s3://crabby-images/570bd/570bd812875ab626667f41ba4a18f318096fd84e" alt="\begin{displaymath}\begin{array}{rcl} T(2^p) & \leq & T(1) + S(2^p) \, {\Sigma}_...
...\frac{1}{2} - 1} \\ & = & T(1) + S(n) \, (2 - 2/n). \end{array}\end{displaymath}" |
(27) |
For
we obtain
data:image/s3,"s3://crabby-images/a72a7/a72a705754d18cf5f42c675c0c8db9ae0ee8b648" alt="\begin{displaymath}\begin{array}{rcl} T(2^p) & \leq & 2^p \, T(1) + S(2^p) \, p \\ & = & n \, T(1) + S(n) \, {\log}_2(n). \end{array}\end{displaymath}" |
(28) |
Marc Moreno Maza
2008-01-07