All of the definitions of Big-O, Big-Ω, and Big-Θ below have something to do with existentially (∃) bound constants (generally
and
) that make definition true. These constants are referred to in the discrete mathematics textbook as witnesses.
Definition of Dominance
Also referred to as asymptotic comparison
In general, we say
is asymptotically less than or equal to (
)
if and only if there exists a natural number
such that
for all
Conversely, we say
is asymptotically greater than or equal to (
)
.
Example
Let
and
:
- When
, data:image/s3,"s3://crabby-images/c65c8/c65c822efba2061cd1edd63e6a07cd5022502b87" alt="{\displaystyle f(n)>g(n)}"
- Asymptotically,
"grows faster" than
, so
≥
when data:image/s3,"s3://crabby-images/8fbdb/8fbdb0fefc5b99f510429271b6f4028e4acaabac" alt="{\displaystyle n>5}"
- Given the definition above, we can say that
data:image/s3,"s3://crabby-images/3467a/3467aa26afad703aa5e3f688cba8a3b25620be20" alt="{\displaystyle 5n\preccurlyeq n^{2}}"
Big O
An upper bound on a function
:
data:image/s3,"s3://crabby-images/aed60/aed6056d2730f492912e8e4f096d0589edd7c00e" alt="{\displaystyle f(n)\in O(n)\rightarrow f(n)\leq Cn\rightarrow f(n)\preccurlyeq n}"
Precise Definition: data:image/s3,"s3://crabby-images/31ead/31ead0f14fce47c8cb6965e6a3912dd57945ca4a" alt="{\displaystyle f(n)}"
is big oh of
data:image/s3,"s3://crabby-images/b13dd/b13ddd667e5bd71c2c314b031e622ccf1cb6df31" alt="{\displaystyle g(n)}"
if and only if there exists a constant
data:image/s3,"s3://crabby-images/b940e/b940efd891366f34b3de7bb6c11e45079312b664" alt="{\displaystyle C}"
and a natural number
data:image/s3,"s3://crabby-images/8eddb/8eddb785ca343839af0037ab6a45a23dbf2f7af5" alt="{\displaystyle n_{0}}"
such that
data:image/s3,"s3://crabby-images/06024/06024ab67ca0c820571c695d3f4a988a96d9d28b" alt="{\displaystyle |f(n)|}"
≤
data:image/s3,"s3://crabby-images/24819/24819cb92ff2e1bfcf505facfe8f03a036a39235" alt="{\displaystyle C|g(n)|}"
for all
Common Order of Dominance
exponential
factorial
polynomial
data:image/s3,"s3://crabby-images/af828/af8285a19a21816a5e458f176c1fb558b92fded1" alt="{\displaystyle O(n\log {n})}"
linear
data:image/s3,"s3://crabby-images/cc896/cc8964efab55d9ba05832eb0539194fda996aee5" alt="{\displaystyle O({\sqrt {n}})}"
logarithmic
constant
Big Ω
A lower bound on a function
[1]:
data:image/s3,"s3://crabby-images/e90ff/e90ff57142011bf0b511a468e1a4e0b5ee037c22" alt="{\displaystyle f(n)\in \Omega (n)\rightarrow f(n)\geq Cn\rightarrow f(n)\succcurlyeq n}"
Precise Definition: data:image/s3,"s3://crabby-images/31ead/31ead0f14fce47c8cb6965e6a3912dd57945ca4a" alt="{\displaystyle f(n)}"
is big omega of
data:image/s3,"s3://crabby-images/b13dd/b13ddd667e5bd71c2c314b031e622ccf1cb6df31" alt="{\displaystyle g(n)}"
if and only if there exists a constant
data:image/s3,"s3://crabby-images/b940e/b940efd891366f34b3de7bb6c11e45079312b664" alt="{\displaystyle C}"
and a natural number
data:image/s3,"s3://crabby-images/8eddb/8eddb785ca343839af0037ab6a45a23dbf2f7af5" alt="{\displaystyle n_{0}}"
such that
data:image/s3,"s3://crabby-images/06024/06024ab67ca0c820571c695d3f4a988a96d9d28b" alt="{\displaystyle |f(n)|}"
≥
data:image/s3,"s3://crabby-images/24819/24819cb92ff2e1bfcf505facfe8f03a036a39235" alt="{\displaystyle C|g(n)|}"
for all
Note: data:image/s3,"s3://crabby-images/46d3f/46d3f55680e8c58a4925229d61831a6d7c418b04" alt="{\displaystyle f(n)=\Omega (g(n))\Leftrightarrow g(n)=O(f(n))}"
Big Θ
Means that function has same asymptotic growth as another function up to multiplication by constants. Similar to squeeze theorem in Calculus for proof of convergence.
data:image/s3,"s3://crabby-images/d2649/d2649237478a683ad10433d4ddbea4e2fb897246" alt="{\displaystyle f(n)\in \Theta (g(n))\longrightarrow \exists \ L<\infty \left(\lim _{n\to \infty }{\frac {|f(n)|}{|g(n)|}}=L\right)}"
Precise Definiton: data:image/s3,"s3://crabby-images/31ead/31ead0f14fce47c8cb6965e6a3912dd57945ca4a" alt="{\displaystyle f(n)}"
is big theta (same order) of
data:image/s3,"s3://crabby-images/b13dd/b13ddd667e5bd71c2c314b031e622ccf1cb6df31" alt="{\displaystyle g(n)}"
if and only if there exists constants
data:image/s3,"s3://crabby-images/80fd6/80fd6c9de156ad99b10a6d8ce7889e245970e97d" alt="{\displaystyle L}"
and
data:image/s3,"s3://crabby-images/f318d/f318dbb8dfb093436d1b70ca0357dfab4385441a" alt="{\displaystyle U}"
and a natural number
data:image/s3,"s3://crabby-images/8eddb/8eddb785ca343839af0037ab6a45a23dbf2f7af5" alt="{\displaystyle n_{0}}"
such that
data:image/s3,"s3://crabby-images/06024/06024ab67ca0c820571c695d3f4a988a96d9d28b" alt="{\displaystyle |f(n)|}"
is between
data:image/s3,"s3://crabby-images/257aa/257aa49900b325f3e5b6908f7b21a3a15f133af8" alt="{\displaystyle L|g(n)|}"
and
data:image/s3,"s3://crabby-images/559b6/559b6b3d0cb69adebec9328d1085046b15cb7c06" alt="{\displaystyle U|g(n)|}"
for all
data:image/s3,"s3://crabby-images/79ae7/79ae797dc226c3db3abeac55e1fab3b129af6017" alt="{\displaystyle n>n_{0}}"
.
In other words,
In this case,
for Big-Θ takes the larger value of the
's used in Big-O and Big-Ω.
Examples
Example 1
- Claim
data:image/s3,"s3://crabby-images/ec826/ec8263313f12ba1ffb3020ae7e0dafd5d51873f2" alt="{\displaystyle 5n=O\left(n^{2}\right)}"
- Choose witnesses
and
(can be derived mathematically to fit the form of the definition of Big-O:
for all
)
data:image/s3,"s3://crabby-images/6234c/6234c6f6c10a445f2c7a9410a3452798139ebd06" alt="{\displaystyle {\begin{Bmatrix}5n&<&5n^{2}\\\left|5n\right|&\leq &5\left|n^{2}\right|\end{Bmatrix}}\ {\mbox{true}}\ \forall \ n\geq 1}"
Example 2
When Joe implements algorithm A in Java and runs it on his home PC. Running time is
data:image/s3,"s3://crabby-images/361be/361be98748eb1d1ef41e043705f81fc44d10cd1a" alt="{\displaystyle f_{1}\left(n\right)=7n+52}"
When Sue implements algorithm A in Fortran and runs it on dilbert.cs.tamu.edu, the running time is
data:image/s3,"s3://crabby-images/67359/673594f428c96cc8aa41edfce7728221d58be148" alt="{\displaystyle f_{2}\left(n\right)=2n+25}"
Resulting speed of both algorithms is
Example 3
Example 4
(See Wikipedia:Binomial coefficient→)
- ↑ comparison-based sorting algorithms need at least
comparisons.