Compare commits
No commits in common. "31f2d077cacc22892e7f4d338cda9f47a2f76de6" and "f001d57f9d2d6fcd3d0d1e987a26917a66f2782b" have entirely different histories.
31f2d077ca
...
f001d57f9d
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
@ -1,428 +0,0 @@
|
||||
* Discrete Math Notes [2024-03-30 Sat 22:51] :journal:cs2233:college:discrete_math:
|
||||
|
||||
** Laws of Propositional Logic
|
||||
:PROPERTIES:
|
||||
:ID: 539a691a-ce6d-4711-84ba-57e74ed42f27
|
||||
:END:
|
||||
*** Domination Laws
|
||||
|
||||
- $p ∧ F ≡ F$
|
||||
- $p ∨ ≡ T$
|
||||
|
||||
*** Double Negation Law
|
||||
|
||||
- $¬¬p ≡ p$
|
||||
|
||||
*** Complement Laws
|
||||
|
||||
- $p ∧ ¬p ≡ F$
|
||||
- $¬T ≡ F$
|
||||
- $p ∨ ¬p ≡ T$
|
||||
- $¬F ≡ T$
|
||||
|
||||
*** De Morgan's Laws
|
||||
|
||||
- $¬(p ∨ q) ≡ ¬p ∧ ¬q$
|
||||
- $¬(p ∧ q) ≡ ¬p ∨ ¬q$
|
||||
|
||||
*** Absorption Laws
|
||||
|
||||
- $p ∨ (p ∧ q) ≡ p$
|
||||
- $p ∧ (p ∨ q) ≡ q$
|
||||
|
||||
*** Idempotent Laws
|
||||
|
||||
- $p ∨ p ≡ p$
|
||||
- $p ∧ p ≡ p$
|
||||
|
||||
*** Associative Laws
|
||||
|
||||
Modifying the location of grouping doesn't modify the output among like operators.
|
||||
|
||||
- $(p ∨ q) ∨ r ≡ p ∨ (q ∨ r)$
|
||||
- $(p ∧ q) ∧ r ≡ p ∧ (q ∧ r)$
|
||||
|
||||
*** Commutative Laws
|
||||
|
||||
Modifying the location of variables doesn't modify the output around like operators.
|
||||
|
||||
- $(p ∨ q) ≡ (q ∨ p)$
|
||||
- $(p ∧ q) ≡ (q ∧ p)$
|
||||
|
||||
*** Distributive Laws
|
||||
|
||||
- $p ∨ (q ∧ r) ≡ (p ∨ q) ∧ (p ∨ r)$
|
||||
- $p ∧ (q ∨ r) ≡ (p ∧ q) ∨ (p ∧ r)$
|
||||
|
||||
*** Identity Laws
|
||||
|
||||
- $p ∨ F ≡ p$
|
||||
- $p ∧ T ≡ T$
|
||||
|
||||
*** Conditional Identities
|
||||
|
||||
- $p → q ≡ ¬p ∨ q$
|
||||
- $p ↔ q ≡ (p → q) ∧ (q → p)$
|
||||
|
||||
** Even and Odd Integers
|
||||
- An integer $x$ is /*even*/ if there is an integer $k$ such that $x = 2k$
|
||||
- An integer $x$ is /*odd*/ if there is an integer $k$ such that $x = 2k + 1$
|
||||
|
||||
** Parity
|
||||
|
||||
- The /*parity*/ of a number is whether the number is odd or even. If two numbers are both even
|
||||
or both odd, then the two numbers have the /*same parity*/. If one number is odd and the other
|
||||
is even is even, then the two numbers have /*opposite parity*/.
|
||||
|
||||
** Rational Numbers
|
||||
- A number $r$ is /*rational*/ if there exist integers $x$ and $y$ such that $y ≠ 0$ and
|
||||
$r = x/y$.
|
||||
|
||||
** Divides
|
||||
|
||||
- An integer $x$ /*divides*/ an integer $y$ if and only if $x ≠ 0$ and $y = kx$, for some
|
||||
integer $k$. The fact that $x$ divides $y$ is denoted $x | y$. If $x$ does not divide $y$, then
|
||||
the fact is denoted $x ∤ y$.
|
||||
|
||||
** Prime and Composite Numbers
|
||||
- An integer $n$ is /*prime*/ if and only if $n > 1$, and the only positive integers that divide
|
||||
$n$ are $1$ and $n$.
|
||||
- An integer $n$ is /*composite*/ if and only if $n > 1$, and there is an integer $m$ such that
|
||||
$1 < m < n$ and $m$ divides $n$.
|
||||
|
||||
** Consecutive Integers
|
||||
- Two integers are /*consecutive*/ if one of the numbers is equal to $1$ plus the other number.
|
||||
Effectively $n = m + 1$.
|
||||
|
||||
** Proof by Contrapositive
|
||||
- A /*proof by contrapositive*/ proves a conditional theorem of the form $p → c$ by showing that
|
||||
the contrapositive $¬c → ¬p$ is true. In other words, $¬c$ is assumed to be true and $¬p$ is
|
||||
proven as a result of $¬c$.
|
||||
|
||||
** Sets
|
||||
|
||||
*** Common Mathematical Sets
|
||||
|
||||
| Set | Symbol | Examples of Elements |
|
||||
|--------------------|--------|---------------------------|
|
||||
| Natural Numbers | ℕ | 0,1,2,3,... |
|
||||
| Integers | ℤ | ...,-2,-1,0,1,2,... |
|
||||
| Rational Numbers | ℚ | 0, 1/2, 5.23,-5/3, 7 |
|
||||
| Irrational Numbers | ℙ | π, √2, √5/3, -4/√6 |
|
||||
| Real Numbers | ℝ | 0, 1/2, 5.23, -5/3, π, √2 |
|
||||
|
||||
*** Subset
|
||||
- If every element in $A$ is also an element of $B$, then $A$ is a /*subset*/ of $B$, denoted as $A ⊆ B$.
|
||||
- If there is an element of $A$ that is not an element of $B$, then $A$ is not a subset of $B$,
|
||||
denoted as $A ⊈ B$.
|
||||
- If the universal set is $U$, then for every set $A$: $Ø ⊆ A ⊆ U$
|
||||
- If $A ⊆ B$ and there is an element of $B$ that is not an element of $A$ (i.e. $A ≠ B$), then
|
||||
$A$ is a /*proper subset*/ of $B$, denoted as $A ⊂ B$.
|
||||
*** Power Set
|
||||
- The /*power set*/ of a set $A$, denoted $P(A)$, is the set of all subsets of $A$. For example
|
||||
if $A = {1,2,3}$, then: $P(A) = {Ø,{1},{2},{3},{1,2},{1,3},{2,3},{1,2,3}}$
|
||||
**** Cardinality of a Power Set
|
||||
- Let $A$ be a finite set of cardinality $n$. Then the cardinality of the power set of $A$ is
|
||||
$2^n$, or $|P(A)| = 2^n$
|
||||
|
||||
*** Set Operations
|
||||
**** Set Intersection
|
||||
|
||||
- Let $A$ and $B$ be sets. The $intersection$ of $A$ and $B$, denoted $A ∩ B$ and read "$A$
|
||||
intersect $B$", is the set of all elements that are elements of both $A$ and $B$.
|
||||
|
||||
**** Set Union
|
||||
|
||||
- The /*union*/ of two sets, $A$ and $B$, denoted $A ∪ B$ and read "$A$ union $B$", is the set
|
||||
of all elements that are elements of $A$ or $B$. The definition for union uses the inclusive
|
||||
or, meaning that if an element is an element of both $A$ and $B$, then it also and element of
|
||||
$A ∪ B$.
|
||||
**** Set Difference
|
||||
- The /*difference*/ between two sets $A$ and $B$, denoted $A - B$, is the set of elements that
|
||||
are in $A$ but not in $B$.
|
||||
- The difference operation is not commutative since it is not necessarily the case that $A - B = B - A$.
|
||||
Consider that $3 - 2 ≠ 2 - 3$, same applies for the set difference operator.
|
||||
|
||||
**** Set Symmetric Difference
|
||||
- The /*symmetric difference*/ between two sets, $A$ and $B$, denoted $A ⊕ B$, is the set of
|
||||
elements that are a member of exactly one of $A$ and $B$, but not both. An alternate
|
||||
definition of the symmetric difference operation is: $A ⊕ B = (A - B) ∪ (B - A)$
|
||||
|
||||
**** Set Complement
|
||||
- The /*complement*/ of a set $A$, denoted $ ̅A$, is the set of all elements in $U$ (the
|
||||
universal set) that are not elements of $A$. An alternate definition of $ ̅A$ is
|
||||
$U - A$.
|
||||
|
||||
*** Summary of Set Operations
|
||||
| Operation | Notation | Description |
|
||||
|----------------------|----------|--------------------------------|
|
||||
| Intersection | $A ∩ B$ | ${x: x ∈ A and x ∈ B}$ |
|
||||
| Union | $A ∪ B$ | ${x: x ∈ A and x ∈ B or both}$ |
|
||||
| Difference | $A - B$ | ${x: x ∈ A and x ∉ B}$ |
|
||||
| Symmetric Difference | $A ⊕ B$ | ${x: x ∈ A - B or x ∈ B - A}$ |
|
||||
| Complement | $ ̅A$ | ${x: x ∉ A}$ |
|
||||
|
||||
*** Set Identities
|
||||
- A /*set identity*/ is an equation involving sets that is true regardless of the contents of the
|
||||
sets in the expression.
|
||||
- Set identities are similar to [[id:539a691a-ce6d-4711-84ba-57e74ed42f27][Laws of Propositional Logic]]
|
||||
- The sets $U$ and $Ø$ correspond to the constants true (T) and false (F):
|
||||
- $A ∈ Ø ↔ F$
|
||||
- $A ∈ U ↔ T$
|
||||
|
||||
[[./assets/set-identities.png][Table of set identities]]
|
||||
|
||||
*** Cartesian Products
|
||||
|
||||
- An /*ordered pair*/ of items is written $(x,y)$
|
||||
- The first /*entry*/ of the ordered pair $(x,y)$ is $x$ and the second entry is $y$
|
||||
- The use of parentheses $()$ for an ordered pair indicates that the order of the entries is
|
||||
significant, unlike sets which use curly braces ${}$
|
||||
- Two ordered pairs $(x,y)$ and $(u,w)$ are equal if and only if $x = u$ and $y = w$
|
||||
- For two sets, $A$ and $B$, the /*Cartesian product*/ of $A$ and $B$ denoted $A × B$, is the
|
||||
set of all ordered pairs in which the first entry is in $A$ and the second entry is in $B$.
|
||||
That is: $A × B = {(a,b): a ∈ A and b ∈ B}$
|
||||
- Since the order of the elements in a pair is significant, $A × B$ will not be the same as
|
||||
$B × A$, unless $A = B$, or either $A$ or $B$ is empty. If $A$ and $B$ are finite sets then
|
||||
$|A × B| = |A| × |B|$
|
||||
|
||||
*** Strings
|
||||
|
||||
- A sequence of characters is called a /*string*/
|
||||
- The set of characters used in a set of strings is called the /*alphabet*/ for the set of
|
||||
strings
|
||||
- The /*length*/ of a string is the number of characters in the string
|
||||
- A /*binary string*/ is a string whose alphabet is {0,1}
|
||||
- A /*bit*/ is a character in a binary string
|
||||
- A binary string of length $n$ is also called an /*$n$-bit string*/
|
||||
- The set of binary strings of length $n$ is denoted as ${0,1}^n$
|
||||
- The /*empty string*/ is the unique string whose length is 0 and is usually denoted by the
|
||||
symbol $λ$. Since ${0,1}^0$ is the set of all binary strings of length 0, ${0,1}^0 = {λ}$
|
||||
- If $s$ and $t$ are two strings, then the /*concatenation*/ of $s$ and $t$ (denoted $st$) is
|
||||
the string obtained by putting $s$ and $t$ together
|
||||
- Concatenating any string $x$ with the empty string ($λ$) gives back: $x: xλ = x$
|
||||
|
||||
** Functions
|
||||
|
||||
_Definition of a function:_
|
||||
#+begin_src typst
|
||||
A function $f$ that maps elements of a set $X$ to elements of a set $Y$, is a subset of $X × Y$
|
||||
such that for every $x ∈ X$, there is exactly one $y ∈ Y$ for which $(x,y) ∈ f$.
|
||||
|
||||
$f: X → Y$ is the notation to express the fact that $f$ is a function from $X$ to $Y$. The set
|
||||
$X$ is called the _*domain*_ of $f$, and the set $Y$ is the _*target*_ of $f$. An alternate word
|
||||
for target that is sometimes used is _*co-domain*_. The fact that $f$ maps $x$ to $y$
|
||||
(or $(x,y) ∈ f$) can also be denoted as $f(x) = y$
|
||||
#+end_src
|
||||
|
||||
- If $f$ maps an element of the domain to zero elements or more than one element of the target,
|
||||
then $f$ is not /*well-defined*/.
|
||||
- If $f$ is a function mapping $X$ to $Y$ and $X$ is a finite set, then the function $f$ can be
|
||||
specified by listing the pairs $(x,y)$ in $f$. Alternatively, a function with a finite domain
|
||||
can be expressed graphically as an arrow diagram.
|
||||
- In an /*arrow diagram*/ for a function $f$, the elements of the domain $X$ are listed on the
|
||||
left and the elements of the target $Y$ are listed on the right. There is an arrow diagram from
|
||||
$x ∈ X$ to $y ∈ Y$ if and only if $(x,y) ∈ f$. Since $f$ is a function, each $x ∈ X$ has
|
||||
exactly one $y ∈ Y$ such that $(x,y) ∈ f$, which means that in the arrow diagram for a
|
||||
function, there is exactly one arrow pointing out of every element in the domain.
|
||||
- See the following example arrow diagram: [[./assets/arrow-diagram.png]]
|
||||
- For function $f: X → Y$, an element $y$ is in the /*range*/ of $f$ if and only if there is an
|
||||
$x ∈ X$ such that $(x,y) ∈ f$.
|
||||
- Expressed in set notation: Range of $f = {y: (x,y) ∈ f, for some x ∈ X}$
|
||||
*** Function Equality
|
||||
|
||||
- Two functions, $f$ and $g$, are /*equal*/ if $f$ and $g$ have the same domain and target, and
|
||||
$f(x) = g(x)$ for every element $x$ in the domain. The notation $f = g$ is used to denote the
|
||||
fact that functions $f$ and $g$ are equal.
|
||||
|
||||
*** The Floor Function
|
||||
|
||||
- The /*floor function*/ maps a real number to the nearest integer in the downwards direction
|
||||
- The floor function is denoted as: $floor(x) = ⌊x⌋$
|
||||
|
||||
*** The Ceiling Function
|
||||
- The /*ceiling function*/ rounds a real number to the nearest integer in the upwards direction
|
||||
- The ceiling function is denoted as: $ceiling(x) = ⌈x⌉$
|
||||
|
||||
*** Properties of Functions
|
||||
- A function $f: X → Y$ is /*one-to-one*/ or /*injective*/ if $x_1 ≠ x_2$ implies that
|
||||
$f(x_1) ≠ f(x_2)$. That is, $f$ maps different elements in $X$ to different elements in $Y$.
|
||||
- A function $f: X → Y$ is /*onto*/ or /*surjective*/ if the range of $f$ is equal to the target
|
||||
$Y$. That is, for every $y ∈ Y$, there is an $x ∈ X$ such that $f(x) = y$.
|
||||
- A function is /*bijective*/ if it is both one-to-one and onto. A bijective function is called a
|
||||
/*bijection*/. A bijection is also called a /*one-to-one correspondence*/.
|
||||
|
||||
*** Composition of Functions
|
||||
- The process of applying a function to the result of another function is called
|
||||
/*composition*/.
|
||||
- Definition of /*function composition*/
|
||||
#+begin_src typst
|
||||
$f$ and $g$ are two function, where $f: X → Y$ and $g: Y → Z$. The composition of $g$ with
|
||||
$f$, denoted $g ○ f$, is the function ($g ○ f): X → Z$, such that for all
|
||||
$x ∈ X, (g ○ f)(x) = g(f(x))$
|
||||
#+end_src
|
||||
- Composition is /associative/
|
||||
- The /*identity function*/ always maps a set onto itself and maps every element onto itself.
|
||||
- The identity function on $A$, denoted $I_A: A → A$, is defined as $I_A(a) = a$, for all
|
||||
$a ∈ A$
|
||||
- If a function $f$ from $A$ to $B$ has an inverse, then $f$ composed with its inverse is the
|
||||
indentity function. If $f(a) = b$, then $f^-1(b) = a$, and
|
||||
$(f^-1 ○ f)(a) = f^-1(f(a)) = f^-1(b) = a$.
|
||||
- Let $f: A → B$ be a bijection. Then $f^-1 ○ f = I_A$ and $f ○ f^-1 = I_B$
|
||||
** Computation
|
||||
|
||||
*** Introduction to Algorithms
|
||||
|
||||
- An /*algorithm*/ is a step-by-step method for solving a problem. A description of an algorithm
|
||||
specifies the input to the problem, the output to the problem, and the sequence of steps to be
|
||||
followed to obtain the output from the input.
|
||||
- A description of an algorithm usually includes
|
||||
- A name for the algorithm
|
||||
- A brief description of the task performed by the algorithm
|
||||
- A description of the input
|
||||
- A description of the output
|
||||
- A sequence of steps to follow
|
||||
- Algorithms are often described in /*pseudocode*/, which is a language between written English
|
||||
and a computer language
|
||||
- An important type of step in an algorithm is an /*assignment*/, in which a variable is given a
|
||||
variable. The assignment operated is denoted by $:=$, for example to assign $x$ to $y$ you
|
||||
would write it as: $x := y$.
|
||||
- The output of an algorithm is specified by a /*return*/ statement.
|
||||
- For example, the statement $Return(x)$ would return the value of $x$ as the output of the
|
||||
algorithm.
|
||||
- A return statement in the middle of an algorithm causes the execution of the algorithm to
|
||||
stop at that point and return the indicated value
|
||||
**** The if-statement and the if-else-statement
|
||||
- An /*if-statement*/ tests a condition, and executes one or more instructions if the condition
|
||||
evaluates to true. In a single line if-statement, a conditon and instruction appear on the
|
||||
same line.
|
||||
- An /*if-else-statement*/ tests a condition, executes one or more instructions if the condition
|
||||
evaluates to true, and executes a different set of instructions in the condition evaluates to
|
||||
false.
|
||||
|
||||
**** The for-loop
|
||||
- In a /*for-loop*/, a block of instructions is executed a fixed number of times as specified in
|
||||
the first line of the for-loop, which defines an /*index*/, a starting value for the index,
|
||||
and a final value for the index.
|
||||
- Each repetition of the block of instructions inside the for-loop is called an
|
||||
/*iteration*/.
|
||||
- The index is initially assigned a value equal to the starting value, and is incremented just
|
||||
before the next iteration begins.
|
||||
- The final iteration of the for-loop happens when the index reaches the final value.
|
||||
|
||||
**** The while-loop
|
||||
- A /*while-loop*/ iterates an unknown number of times, ending when a certain condition becomes
|
||||
false.
|
||||
*** Asymptotic Growth of Functions
|
||||
|
||||
- The /*asymptotic growth*/ of the function $f$ is a measure of how fast the output $f(n)$ grows
|
||||
as the input $n$ grows.
|
||||
- Classification of functions using Oh, $Ω$, and $Θ$ notation (called /*asymptotic notation*/)
|
||||
provides a way to concisely characterize the asymptotic growth of a function.
|
||||
|
||||
**** O-notation
|
||||
- The notation $f = O(g)$ is read "$f$ is /*Oh of*/ $g$". $f = O(g)$ essentially means that the
|
||||
function $f(n)$ is less than or equal to $g(n)$, if constant factors are omitted and small
|
||||
values for $n$ are ignored.
|
||||
- The $O$ notation serves as a rough upper bound for functions (disregarding constants and
|
||||
small input values)
|
||||
- In the expressions $7n^3$ and $5n^2$, the $7$ and the $5$ are called /*constant factors*/
|
||||
because the values of $7$ and $5$ do not depend on the variable $n$.
|
||||
- If $f$ is $O(g)$, then there is a positive number $c$ such that when $f(n)$ and $c × g(n)$ are
|
||||
graphed, the graph of $c × g(n)$ will eventually cross $f(n)$ and remain higher than $f(n)$
|
||||
as $n$ gets large.
|
||||
- Definition: /Oh notation/
|
||||
#+begin_src typst
|
||||
Let $f$ and $g$ be functions from $ℤ^+$ to $ℝ^>=$. Then $f = O(g)$ if there are positive real
|
||||
numbers $c$ and $n_0$ such that for any $n ∈ ℤ^+$ such that $n >= n_0$: $f(n) <= c × g(n)$.
|
||||
#+end_src
|
||||
- The constants $c$ and $n_0$ in the definition of Oh-notation are said to be a /*witness*/ to
|
||||
the fact that $f = O(g)$.
|
||||
|
||||
**** Ω Notation
|
||||
- The $Ω$ notation provides a lower bound on the growth of a function
|
||||
- $Ω$ notation definition:
|
||||
#+begin_src typst
|
||||
Let $f$ and $g$ be functions from $ℤ^+$ to $ℝ^>=$. Then $f = Ω(g)$ if there are positive real
|
||||
numbers $c$ and $n_0$ such that for any $n ∈ ℤ^+$ such that for $n >= n_0$,
|
||||
|
||||
$f(n) >= c × g(n)$
|
||||
|
||||
The notation $f = Ω(g)$ is read "$f$ is _*Omega*_ of $g$".
|
||||
#+end_src
|
||||
|
||||
- Relationship between Oh-notation and $Ω$-notation:
|
||||
#+begin_src typst
|
||||
Let $f$ and $g$ be functions from $ℤ^+$ to $ℝ^>=$. Then $f = Ω(g)$ if and only if $g = O(f)$
|
||||
#+end_src
|
||||
|
||||
**** 𝛩 notation and polynomials
|
||||
- The $𝛩$ notation indicates that two functions have the same rate of growth
|
||||
- $𝛩$-notation definition:
|
||||
#+begin_src typst
|
||||
Let $f$ and $g$ be functions from $ℤ^+$ to $ℝ^>=$.
|
||||
|
||||
$f = 𝛩(g)$ if $f = O(g)$ and $f = Ω(g)$
|
||||
|
||||
The notation $f = 𝛩(g)$ is read "$f$ is *_Theta of_* $g(n)$"
|
||||
#+end_src
|
||||
- If $f = 𝛩(g)$, then $f$ is said to be /*order of*/ $g$.
|
||||
- /*Lower order*/ terms are those that can be removed from $f$ that does not change the /order/
|
||||
of $f$.
|
||||
|
||||
**** Asymptotic growth of polynomials
|
||||
#+begin_src typst
|
||||
Let $p(n)$ be a degree-$k$ polynomial of the form:
|
||||
|
||||
$p(n) = a_kn^k + ... + a_1n + a_0$
|
||||
|
||||
in which $a_k > 0$. Then $p(n)$ is $𝛩(n^k)$
|
||||
#+end_src
|
||||
|
||||
**** Asymptotic growth of logarithm functions with different bases
|
||||
|
||||
Let $a$ and $b$ be two real numbers greater than $1$, then $log_a(n) = 𝛩(log_b(n))$
|
||||
|
||||
**** Growth rate of common functions in analysis of algorithms
|
||||
|
||||
- A function that does not depend on $n$ at all is called a /*constant function*/. $f(n) = 17$
|
||||
is an example of a constant function.
|
||||
- Any constant function is $𝛩(1)$.
|
||||
- If a function $f(n)$ is $𝛩(n)$, we say that $f(n)$ is a =linear= function.
|
||||
- A function $f(n)$ is said to be /*polynomial*/ if $f(n)$ is $𝛩(n^k)$ for some positive real
|
||||
number $k$.
|
||||
|
||||
**** Common functions in algorithmic complexity.
|
||||
|
||||
The following table of functions are given in increasing order of complexity, with the $m$
|
||||
in the third from the bottom being any $m > 3$:
|
||||
[[./assets/common-funcs-algo-complexity.png][Table here]]
|
||||
|
||||
**** Rules about asymptotic growth
|
||||
|
||||
[[./assets/rules-asymptotic-growth-of-functions.png][See here]]
|
||||
|
||||
*** Analysis of algorithms
|
||||
|
||||
- The amount of resources used by an algorithm is referred to as the algorithm's
|
||||
/*computational complexity*/.
|
||||
- The primary resources to optimize are the time the algorithm requires to run
|
||||
(/*time complexity*/) and the amount of memory used (/*space complexity*/).
|
||||
- The /*time complexity*/ of an algorithm is defined by a function $f: ℤ^+ → ℤ^+$ such that $f(n)$
|
||||
is the maximum number of atomic operations performed by the algorithm on any input of
|
||||
size $n$. $ℤ^+$ is the set of positive integers.
|
||||
- The /*asymptotic time complexity*/ of an algorithm is the rate of asymptotic growth of the
|
||||
algorithm's time complexity function $f(n)$.
|
||||
|
||||
**** Worst-case complexity
|
||||
- The /*worst-case analysis*/ of an algorithm evaluates the time complexity of the algorithm on
|
||||
the input of a particular size that takes the longest time.
|
||||
- The /*worst-case*/ time complexity function $f(n)$ is defined to be the maximum number of
|
||||
atomic operations the algorithm requires, where the maximum is taken over all inputs of size
|
||||
$n$.
|
||||
- When proving an /*upper bound*/ on the worst-case complexity of an algorithm (using
|
||||
$O$-notation), the upper bound must apply for every input of size $n$.
|
||||
- When proving a /*lower bound*/ for the worst-case complexity of an algorithm (using
|
||||
$Ω$-notation), the lower bound need only apply for at least one possible input of size $n$.
|
||||
- /*Average-case analysis*/ evaluates the time complexity of an algorithm by determining the
|
||||
average running time of the algorithm on a random input.
|
Binary file not shown.
Before Width: | Height: | Size: 35 KiB |
Binary file not shown.
Before Width: | Height: | Size: 70 KiB |
Binary file not shown.
Before Width: | Height: | Size: 84 KiB |
Binary file not shown.
Before Width: | Height: | Size: 118 KiB |
Loading…
x
Reference in New Issue
Block a user