« previous | Monday, October 17, 2011 | next »
Recursively Defined Sets
Basis step.
Inductive step. if
, then
.
Example property:
Proof by structural induction.
data:image/s3,"s3://crabby-images/d1247/d1247b3892bd91ee6a2c21711235c1a271da5a03" alt="{\displaystyle S\subseteq 3\mathbb {Z^{+}} }"
data:image/s3,"s3://crabby-images/0ca18/0ca18ae45f38f7d49be476f11a5cf4eab504a755" alt="{\displaystyle 3\mathbb {Z^{+}} \subseteq S}"
(1) Basis step.
Inductive step. Assume
for
. Then
and
for some
.
Hence
. THis proves the inductive step, and
followl by structural principle of mathematical induction.
(2) Basis step.
by definition of
Inductive step. Assume
for
, then
by recursive step definition of
. This proves the inductive step and thus the general result
follows by the principle of mathematical induction.
Properties of S
Basis step. 3 has a property
Recursive step. If
have the property
, then
has the property
This is an example of structural induction.
Strong Properties of S
Basis Step. Something has a certain property
Inductive Step. Any element which can be obtained either by the basis step or up to
iterations for some
of recursive step has property
. Show any such element that can be obtained by
iterations of recursive steps has property
.
Trees
Basis step. A root
is a tree
Inductive step. Let
be
disjoint rooted trees such that
with corresponding roots
. Draw edges connecting another distinct root
with each of the roots
.
, the resulting graph, is a rooted tree.
Example Structural Proof
This proof is for full binary trees in which each node is a leaf or has exactly two children.
Theorem.
, where
is the number of vertices and
is the height.
Proof by Structural Induction.
Basis step.
is a root alone:
,
.
true.
Recursive step. Assume
and
are full binary trees satisfying the theorem
data:image/s3,"s3://crabby-images/4afa3/4afa3024fb7e4e0f08e40dd8732a73d577e1df91" alt="{\displaystyle n(T_{1}\cdot T_{2})=n(T_{1})+n(T_{2})+1}"
Thus we have
for
Adding the two formulae together gives
data:image/s3,"s3://crabby-images/b6675/b66755e77b065633080e0247ea903091f9792e15" alt="{\displaystyle {\begin{aligned}2h(T_{1})+2h(T_{2})+2+1\leq n(T_{1})+n(T_{2})+1&\leq 2^{h(T_{1})+1}-1+2^{h(T_{2})+1}-1+1\\2\left(\mathrm {max} (h(T_{1}),\ h(T_{2}))+1\right)\leq n(T_{1}\cdot T_{2})&\leq 2\cdot 2^{\mathrm {max} (h(T_{1}),\ h(T_{2}))+1}-1\\2h(T_{1}\cdot T_{2})+1\leq n(T_{1}\cdot T_{2})&\leq 2^{h(T_{1}\cdot T_{2})+1}-1\end{aligned}}}"
This proves the inductive step, and the general result follows by the structural principle of mathematical induction.
Q.E.D.
And now for something completely different.
Recursive Algorithms
Solving a problem by reducing it to the same problem with a smaller input.
Simple definition for Factorial
Basis step.
Recursive step.
for
def factorial n
raise Exception.new("must be nonnegative") if n < 0
return 1 if n == 0
n * factorial(n-1)
end
Greatest Common Divisor
def gcd a, b
return b if a == 0
gcd(b % a, a)
end
Note: if
, then a and b are relatively prime.