Compare commits
2 Commits
f001d57f9d
...
31f2d077ca
Author | SHA1 | Date | |
---|---|---|---|
31f2d077ca | |||
b4c078afe2 |
BIN
Spring-2023/CS-2124/Lectures/Course/Lecture-10.1-B-Trees.pdf
Normal file
BIN
Spring-2023/CS-2124/Lectures/Course/Lecture-10.1-B-Trees.pdf
Normal file
Binary file not shown.
BIN
Spring-2023/CS-2124/Lectures/Course/Lecture-10.2-B-Trees.pdf
Normal file
BIN
Spring-2023/CS-2124/Lectures/Course/Lecture-10.2-B-Trees.pdf
Normal file
Binary file not shown.
Binary file not shown.
Binary file not shown.
428
Spring-2023/CS-2233/Notes.org
Normal file
428
Spring-2023/CS-2233/Notes.org
Normal file
@ -0,0 +1,428 @@
|
||||
* 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.
|
BIN
Spring-2023/CS-2233/assets/arrow-diagram.png
Normal file
BIN
Spring-2023/CS-2233/assets/arrow-diagram.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 35 KiB |
BIN
Spring-2023/CS-2233/assets/common-funcs-algo-complexity.png
Normal file
BIN
Spring-2023/CS-2233/assets/common-funcs-algo-complexity.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 70 KiB |
Binary file not shown.
After Width: | Height: | Size: 84 KiB |
BIN
Spring-2023/CS-2233/assets/set-identities.png
Normal file
BIN
Spring-2023/CS-2233/assets/set-identities.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 118 KiB |
Loading…
x
Reference in New Issue
Block a user