mirror of
https://github.com/mfocko/blog.git
synced 2025-02-18 22:37:11 +01:00
feat: don't reference FI MU subjects by their codes
Signed-off-by: Matej Focko <mfocko@redhat.com>
This commit is contained in:
parent
f81d3219e6
commit
e1dea0cdbc
232 changed files with 225 additions and 191 deletions
|
@ -1,5 +1,5 @@
|
||||||
---
|
---
|
||||||
id: ib002-intro
|
id: algorithms-intro
|
||||||
title: Introduction
|
title: Introduction
|
||||||
slug: /
|
slug: /
|
||||||
---
|
---
|
|
@ -4,17 +4,17 @@ title: Vague postconditions and proving correctness of algorithms
|
||||||
description: |
|
description: |
|
||||||
Debugging and testing with precise postconditions.
|
Debugging and testing with precise postconditions.
|
||||||
tags:
|
tags:
|
||||||
- python
|
- python
|
||||||
- testing
|
- testing
|
||||||
- postconditions
|
- postconditions
|
||||||
- sorting
|
- sorting
|
||||||
last_update:
|
last_update:
|
||||||
date: 2021-03-18
|
date: 2021-03-18
|
||||||
---
|
---
|
||||||
|
|
||||||
## Introduction
|
## Introduction
|
||||||
|
|
||||||
[Source code](pathname:///files/ib002/algorithms-correctness/postcondition-ambiguity/test_sort.py) used later on.
|
[Source code](pathname:///files/algorithms/algorithms-correctness/postcondition-ambiguity/test_sort.py) used later on.
|
||||||
|
|
||||||
## Implementation of select sort from the exercises
|
## Implementation of select sort from the exercises
|
||||||
|
|
|
@ -4,11 +4,11 @@ title: Time complexity of ‹extend›
|
||||||
description: |
|
description: |
|
||||||
How to make inefficient algorithm unknowingly.
|
How to make inefficient algorithm unknowingly.
|
||||||
tags:
|
tags:
|
||||||
- c
|
- c
|
||||||
- python
|
- python
|
||||||
- dynamic array
|
- dynamic array
|
||||||
- time complexity
|
- time complexity
|
||||||
- recursion
|
- recursion
|
||||||
last_update:
|
last_update:
|
||||||
date: 2021-03-31
|
date: 2021-03-31
|
||||||
---
|
---
|
||||||
|
@ -86,8 +86,8 @@ As we could observe in the example above, `extend` iterates over all of the elem
|
||||||
|
|
||||||
Consider constructing of this list:
|
Consider constructing of this list:
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/5f306/5f306d913388051182b1cefe989811522ca82dba" alt="Rendered construction of the list"
|
data:image/s3,"s3://crabby-images/c5dc5/c5dc5348e98e0bce2204ae2d29c567bca6884417" alt="Rendered construction of the list"
|
||||||
data:image/s3,"s3://crabby-images/8e14c/8e14ce2cd24fd807ec22c3ca90a751e09830a938" alt="Rendered construction of the list"
|
data:image/s3,"s3://crabby-images/09a17/09a17522beaa16da3e46838dd1640d6fbcf399a1" alt="Rendered construction of the list"
|
||||||
|
|
||||||
Let us assume that you extend the result with the list that you get from the recursive call.
|
Let us assume that you extend the result with the list that you get from the recursive call.
|
||||||
|
|
||||||
|
@ -108,8 +108,8 @@ If the recursion had bigger depth and/or more elements, it would iterate through
|
||||||
|
|
||||||
There is an example of dynamic array:
|
There is an example of dynamic array:
|
||||||
|
|
||||||
- [interface (`dynlist.h`)](pathname:///files/ib002/time-complexity/extend/dynlist.h)
|
- [interface (`dynlist.h`)](pathname:///files/algorithms/time-complexity/extend/dynlist.h)
|
||||||
- [implementation (`dynlist.c`)](pathname:///files/ib002/time-complexity/extend/dynlist.c)
|
- [implementation (`dynlist.c`)](pathname:///files/algorithms/time-complexity/extend/dynlist.c)
|
||||||
|
|
||||||
For the sake of _Algorithms and Data Structures I_ we consider `APPEND` operation, i.e. adding the element to the end of the list, to have time complexity $\mathcal{O}(1)$ (**amortized**; which is out of the scope of IB002).
|
For the sake of _Algorithms and Data Structures I_ we consider `APPEND` operation, i.e. adding the element to the end of the list, to have time complexity $\mathcal{O}(1)$ (**amortized**; which is out of the scope of IB002).
|
||||||
|
|
|
@ -4,15 +4,15 @@ title: Recursion and backtracking with Robot Karel
|
||||||
description: |
|
description: |
|
||||||
A problem with too many restrictions.
|
A problem with too many restrictions.
|
||||||
tags:
|
tags:
|
||||||
- python
|
- python
|
||||||
- karel
|
- karel
|
||||||
- recursion
|
- recursion
|
||||||
- backtracking
|
- backtracking
|
||||||
last_update:
|
last_update:
|
||||||
date: 2022-11-29
|
date: 2022-11-29
|
||||||
---
|
---
|
||||||
|
|
||||||
- [Sources](pathname:///files/ib002/recursion/karel-1.tar.gz)
|
- [Sources](pathname:///files/algorithms/recursion/karel-1.tar.gz)
|
||||||
|
|
||||||
## Introduction
|
## Introduction
|
||||||
|
|
||||||
|
@ -81,7 +81,7 @@ your mind. Ideally:
|
||||||
|
|
||||||
- Write down a nested list of the problems, e.g.
|
- Write down a nested list of the problems, e.g.
|
||||||
|
|
||||||
:::info Example
|
:::info Example
|
||||||
|
|
||||||
Problem: I want to find out whether the display on smartphone should rotate.
|
Problem: I want to find out whether the display on smartphone should rotate.
|
||||||
|
|
||||||
|
@ -94,6 +94,7 @@ your mind. Ideally:
|
||||||
- How can I process it?
|
- How can I process it?
|
||||||
|
|
||||||
:::
|
:::
|
||||||
|
|
||||||
- Write down list of problems that can happen, e.g.
|
- Write down list of problems that can happen, e.g.
|
||||||
|
|
||||||
:::info Example continued
|
:::info Example continued
|
||||||
|
@ -105,6 +106,7 @@ your mind. Ideally:
|
||||||
- What if my formulas are wrong?
|
- What if my formulas are wrong?
|
||||||
|
|
||||||
:::
|
:::
|
||||||
|
|
||||||
- Write down **anything** you consider important to solving the problem, e.g.
|
- Write down **anything** you consider important to solving the problem, e.g.
|
||||||
|
|
||||||
:::info Example continued once again
|
:::info Example continued once again
|
||||||
|
@ -164,4 +166,4 @@ it out by yourself without any influence of “example solution”.
|
||||||
|
|
||||||
If you want to get any feedback, feel free to mail me your solution (including
|
If you want to get any feedback, feel free to mail me your solution (including
|
||||||
all the steps that lead to your final solution, if you wish to get feedback on
|
all the steps that lead to your final solution, if you wish to get feedback on
|
||||||
those too).
|
those too).
|
|
@ -4,13 +4,13 @@ title: Introduction to dynamic programming
|
||||||
description: |
|
description: |
|
||||||
Solving a problem in different ways.
|
Solving a problem in different ways.
|
||||||
tags:
|
tags:
|
||||||
- java
|
- java
|
||||||
- recursion
|
- recursion
|
||||||
- exponential
|
- exponential
|
||||||
- greedy
|
- greedy
|
||||||
- dynamic-programming
|
- dynamic-programming
|
||||||
- top-down-dp
|
- top-down-dp
|
||||||
- bottom-up-dp
|
- bottom-up-dp
|
||||||
last_updated:
|
last_updated:
|
||||||
date: 2023-08-17
|
date: 2023-08-17
|
||||||
---
|
---
|
||||||
|
@ -26,6 +26,7 @@ We are given a 2D array of integers and we are to find the _slide down_.
|
||||||
_Slide down_ is a maximum sum of consecutive numbers from the top to the bottom.
|
_Slide down_ is a maximum sum of consecutive numbers from the top to the bottom.
|
||||||
|
|
||||||
Let's have a look at few examples. Consider the following pyramid:
|
Let's have a look at few examples. Consider the following pyramid:
|
||||||
|
|
||||||
```
|
```
|
||||||
3
|
3
|
||||||
7 4
|
7 4
|
||||||
|
@ -34,6 +35,7 @@ Let's have a look at few examples. Consider the following pyramid:
|
||||||
```
|
```
|
||||||
|
|
||||||
This pyramid has following slide down:
|
This pyramid has following slide down:
|
||||||
|
|
||||||
```
|
```
|
||||||
*3
|
*3
|
||||||
*7 4
|
*7 4
|
||||||
|
@ -44,6 +46,7 @@ This pyramid has following slide down:
|
||||||
And its value is `23`.
|
And its value is `23`.
|
||||||
|
|
||||||
We can also have a look at a _bigger_ example:
|
We can also have a look at a _bigger_ example:
|
||||||
|
|
||||||
```
|
```
|
||||||
75
|
75
|
||||||
95 64
|
95 64
|
||||||
|
@ -61,6 +64,7 @@ We can also have a look at a _bigger_ example:
|
||||||
63 66 4 68 89 53 67 30 73 16 69 87 40 31
|
63 66 4 68 89 53 67 30 73 16 69 87 40 31
|
||||||
4 62 98 27 23 9 70 98 73 93 38 53 60 4 23
|
4 62 98 27 23 9 70 98 73 93 38 53 60 4 23
|
||||||
```
|
```
|
||||||
|
|
||||||
Slide down in this case is equal to `1074`.
|
Slide down in this case is equal to `1074`.
|
||||||
|
|
||||||
## Solving the problem
|
## Solving the problem
|
||||||
|
@ -76,6 +80,7 @@ For all of the following solutions I will be using basic `main` function that
|
||||||
will output `true`/`false` based on the expected output of our algorithm. Any
|
will output `true`/`false` based on the expected output of our algorithm. Any
|
||||||
other differences will lie only in the solutions of the problem. You can see the
|
other differences will lie only in the solutions of the problem. You can see the
|
||||||
`main` here:
|
`main` here:
|
||||||
|
|
||||||
```java
|
```java
|
||||||
public static void main(String[] args) {
|
public static void main(String[] args) {
|
||||||
System.out.print("Test #1: ");
|
System.out.print("Test #1: ");
|
||||||
|
@ -141,6 +146,7 @@ public static int longestSlideDown(int[][] pyramid) {
|
||||||
```
|
```
|
||||||
|
|
||||||
As you can see, we have 2 overloads:
|
As you can see, we have 2 overloads:
|
||||||
|
|
||||||
```java
|
```java
|
||||||
int longestSlideDown(int[][] pyramid);
|
int longestSlideDown(int[][] pyramid);
|
||||||
int longestSlideDown(int[][] pyramid, int row, int col);
|
int longestSlideDown(int[][] pyramid, int row, int col);
|
||||||
|
@ -162,6 +168,7 @@ really is a naïve solution, the time complexity is pretty bad. Let's find the
|
||||||
worst case scenario.
|
worst case scenario.
|
||||||
|
|
||||||
Let's start with the first overload:
|
Let's start with the first overload:
|
||||||
|
|
||||||
```java
|
```java
|
||||||
public static int longestSlideDown(int[][] pyramid) {
|
public static int longestSlideDown(int[][] pyramid) {
|
||||||
return longestSlideDown(pyramid, 0, 0);
|
return longestSlideDown(pyramid, 0, 0);
|
||||||
|
@ -208,6 +215,7 @@ choosing the under and right both. They are separate computations though, so we
|
||||||
are branching from each call of `longestSlideDown`, unless it's a base case.
|
are branching from each call of `longestSlideDown`, unless it's a base case.
|
||||||
|
|
||||||
What does that mean for us then? We basically get
|
What does that mean for us then? We basically get
|
||||||
|
|
||||||
$$
|
$$
|
||||||
T(y) =
|
T(y) =
|
||||||
\begin{cases}
|
\begin{cases}
|
||||||
|
@ -217,6 +225,7 @@ T(y) =
|
||||||
$$
|
$$
|
||||||
|
|
||||||
That looks rather easy to compute, isn't it? If you sum it up, you'll get:
|
That looks rather easy to compute, isn't it? If you sum it up, you'll get:
|
||||||
|
|
||||||
$$
|
$$
|
||||||
T(rows) \in \mathcal{O}(2^{rows})
|
T(rows) \in \mathcal{O}(2^{rows})
|
||||||
$$
|
$$
|
||||||
|
@ -256,6 +265,7 @@ optimal option at the moment.
|
||||||
|
|
||||||
We can try to adjust the naïve solution. The most problematic part are the
|
We can try to adjust the naïve solution. The most problematic part are the
|
||||||
recursive calls. Let's apply the greedy approach there:
|
recursive calls. Let's apply the greedy approach there:
|
||||||
|
|
||||||
```java
|
```java
|
||||||
public static int longestSlideDown(int[][] pyramid, int row, int col) {
|
public static int longestSlideDown(int[][] pyramid, int row, int col) {
|
||||||
if (row == pyramid.length - 1) {
|
if (row == pyramid.length - 1) {
|
||||||
|
@ -282,6 +292,7 @@ we simply go left.
|
||||||
We have switched from _adding the maximum_ to _following the “bigger” path_, so
|
We have switched from _adding the maximum_ to _following the “bigger” path_, so
|
||||||
we improved the time complexity tremendously. We just go down the pyramid all
|
we improved the time complexity tremendously. We just go down the pyramid all
|
||||||
the way to the bottom. Therefore we are getting:
|
the way to the bottom. Therefore we are getting:
|
||||||
|
|
||||||
$$
|
$$
|
||||||
\mathcal{O}(rows)
|
\mathcal{O}(rows)
|
||||||
$$
|
$$
|
||||||
|
@ -291,6 +302,7 @@ We have managed to convert our exponential solution into a linear one.
|
||||||
### Running the tests
|
### Running the tests
|
||||||
|
|
||||||
However, if we run the tests, we notice that the second test failed:
|
However, if we run the tests, we notice that the second test failed:
|
||||||
|
|
||||||
```
|
```
|
||||||
Test #1: passed
|
Test #1: passed
|
||||||
Test #2: failed
|
Test #2: failed
|
||||||
|
@ -301,6 +313,7 @@ algorithms are not the ideal solution to **all** problems. In this case there
|
||||||
may be a solution that is bigger than the one found using the greedy algorithm.
|
may be a solution that is bigger than the one found using the greedy algorithm.
|
||||||
|
|
||||||
Imagine the following pyramid:
|
Imagine the following pyramid:
|
||||||
|
|
||||||
```
|
```
|
||||||
1
|
1
|
||||||
2 3
|
2 3
|
||||||
|
@ -310,6 +323,7 @@ Imagine the following pyramid:
|
||||||
```
|
```
|
||||||
|
|
||||||
We start at the top:
|
We start at the top:
|
||||||
|
|
||||||
1. Current cell: `1`, we can choose from `2` and `3`, `3` looks better, so we
|
1. Current cell: `1`, we can choose from `2` and `3`, `3` looks better, so we
|
||||||
choose it.
|
choose it.
|
||||||
2. Current cell: `3`, we can choose from `6` and `7`, `7` looks better, so we
|
2. Current cell: `3`, we can choose from `6` and `7`, `7` looks better, so we
|
||||||
|
@ -429,6 +443,7 @@ that!
|
||||||
|
|
||||||
Overall we are doing the same things for almost[^2] all of the positions within
|
Overall we are doing the same things for almost[^2] all of the positions within
|
||||||
the pyramid:
|
the pyramid:
|
||||||
|
|
||||||
1. We calculate and store it (using the partial results stored in cache). This
|
1. We calculate and store it (using the partial results stored in cache). This
|
||||||
is done only once.
|
is done only once.
|
||||||
|
|
||||||
|
@ -452,8 +467,9 @@ the pyramid:
|
||||||
:::
|
:::
|
||||||
|
|
||||||
Our final upper bound of this work is therefore $\log_2{n}$.
|
Our final upper bound of this work is therefore $\log_2{n}$.
|
||||||
|
|
||||||
2. We retrieve it from the cache. Same as in first point, but only twice, so we
|
2. We retrieve it from the cache. Same as in first point, but only twice, so we
|
||||||
get $2 \cdot \log_2{n}$.
|
get $2 \cdot \log_2{n}$.
|
||||||
|
|
||||||
:::caution
|
:::caution
|
||||||
|
|
||||||
|
@ -465,6 +481,7 @@ Okay, we have evaluated work done for each of the cells in the pyramid and now
|
||||||
we need to put it together.
|
we need to put it together.
|
||||||
|
|
||||||
Let's split the time complexity of our solution into two operands:
|
Let's split the time complexity of our solution into two operands:
|
||||||
|
|
||||||
$$
|
$$
|
||||||
\mathcal{O}(r + s)
|
\mathcal{O}(r + s)
|
||||||
$$
|
$$
|
||||||
|
@ -473,6 +490,7 @@ $r$ will represent the _actual_ calculation of the cells and $s$ will represent
|
||||||
the additional retrievals on top of the calculation.
|
the additional retrievals on top of the calculation.
|
||||||
|
|
||||||
We calculate the values only **once**, therefore we can safely agree on:
|
We calculate the values only **once**, therefore we can safely agree on:
|
||||||
|
|
||||||
$$
|
$$
|
||||||
\begin{align*}
|
\begin{align*}
|
||||||
r &= n \cdot \log{n} \\
|
r &= n \cdot \log{n} \\
|
||||||
|
@ -482,6 +500,7 @@ $$
|
||||||
What about the $s$ though? Key observation here is the fact that we have 2
|
What about the $s$ though? Key observation here is the fact that we have 2
|
||||||
lookups on the tree in each of them **and** we do it twice, cause each cell has
|
lookups on the tree in each of them **and** we do it twice, cause each cell has
|
||||||
at most 2 parents:
|
at most 2 parents:
|
||||||
|
|
||||||
$$
|
$$
|
||||||
\begin{align*}
|
\begin{align*}
|
||||||
s &= n \cdot 2 \cdot \left( 2 \cdot \log{n} \right) \\
|
s &= n \cdot 2 \cdot \left( 2 \cdot \log{n} \right) \\
|
||||||
|
@ -496,6 +515,7 @@ of the results. This is not entirely true, since we have included the
|
||||||
`.containsKey()` and `.get()` from the `return` statement in the second part.
|
`.containsKey()` and `.get()` from the `return` statement in the second part.
|
||||||
|
|
||||||
If we were to represent this more precisely, we could've gone with:
|
If we were to represent this more precisely, we could've gone with:
|
||||||
|
|
||||||
$$
|
$$
|
||||||
\begin{align*}
|
\begin{align*}
|
||||||
r &= 3 \cdot n \cdot \log{n} \\
|
r &= 3 \cdot n \cdot \log{n} \\
|
||||||
|
@ -512,6 +532,7 @@ doesn't really matter.
|
||||||
|
|
||||||
And so our final time complexity for the whole _top-down dynamic programming_
|
And so our final time complexity for the whole _top-down dynamic programming_
|
||||||
approach is:
|
approach is:
|
||||||
|
|
||||||
$$
|
$$
|
||||||
\mathcal{O}(r + s) \\
|
\mathcal{O}(r + s) \\
|
||||||
\mathcal{O}(n \cdot \log{n} + 4 \cdot n \cdot \log{n}) \\
|
\mathcal{O}(n \cdot \log{n} + 4 \cdot n \cdot \log{n}) \\
|
||||||
|
@ -531,11 +552,13 @@ down. At the end we get the final result for `new Position(0, 0)`, so we need to
|
||||||
compute everything below.
|
compute everything below.
|
||||||
|
|
||||||
That's how we obtain:
|
That's how we obtain:
|
||||||
|
|
||||||
$$
|
$$
|
||||||
\mathcal{O}(n)
|
\mathcal{O}(n)
|
||||||
$$
|
$$
|
||||||
|
|
||||||
$n$ represents the total amount of cells in the pyramid, i.e.
|
$n$ represents the total amount of cells in the pyramid, i.e.
|
||||||
|
|
||||||
$$
|
$$
|
||||||
\sum_{y=0}^{\mathtt{pyramid.length} - 1} \mathtt{pyramid}\left[y\right]\mathtt{.length}
|
\sum_{y=0}^{\mathtt{pyramid.length} - 1} \mathtt{pyramid}\left[y\right]\mathtt{.length}
|
||||||
$$
|
$$
|
||||||
|
@ -553,6 +576,7 @@ number.
|
||||||
|
|
||||||
Yes, it can! Try to think about a way, how can you minimize the memory
|
Yes, it can! Try to think about a way, how can you minimize the memory
|
||||||
complexity of this approach. I'll give you a hint:
|
complexity of this approach. I'll give you a hint:
|
||||||
|
|
||||||
$$
|
$$
|
||||||
\mathcal{O}(rows)
|
\mathcal{O}(rows)
|
||||||
$$
|
$$
|
||||||
|
@ -578,6 +602,7 @@ to implement right from the beginning.
|
||||||
:::
|
:::
|
||||||
|
|
||||||
Let's see how we can implement it:
|
Let's see how we can implement it:
|
||||||
|
|
||||||
```java
|
```java
|
||||||
public static int longestSlideDown(int[][] pyramid) {
|
public static int longestSlideDown(int[][] pyramid) {
|
||||||
// In the beginning we declare new array. At this point it is easier to just
|
// In the beginning we declare new array. At this point it is easier to just
|
||||||
|
@ -647,6 +672,7 @@ the best **overall** result I can achieve.
|
||||||
Time complexity of this solution is rather simple. We allocate an array for the
|
Time complexity of this solution is rather simple. We allocate an array for the
|
||||||
rows and then for each row, we copy it and adjust the partial results. Doing
|
rows and then for each row, we copy it and adjust the partial results. Doing
|
||||||
this we get:
|
this we get:
|
||||||
|
|
||||||
$$
|
$$
|
||||||
\mathcal{O}(rows + 2n)
|
\mathcal{O}(rows + 2n)
|
||||||
$$
|
$$
|
||||||
|
@ -658,6 +684,7 @@ once.
|
||||||
|
|
||||||
We're allocating an array for the pyramid **again** for our partial results, so
|
We're allocating an array for the pyramid **again** for our partial results, so
|
||||||
we get:
|
we get:
|
||||||
|
|
||||||
$$
|
$$
|
||||||
\mathcal{O}(n)
|
\mathcal{O}(n)
|
||||||
$$
|
$$
|
||||||
|
@ -695,11 +722,11 @@ successor and represents the way we can enhance the existing implementation.
|
||||||
:::info source
|
:::info source
|
||||||
|
|
||||||
You can find source code referenced in the text
|
You can find source code referenced in the text
|
||||||
[here](pathname:///files/ib002/recursion/pyramid-slide-down.tar.gz).
|
[here](pathname:///files/algorithms/recursion/pyramid-slide-down.tar.gz).
|
||||||
|
|
||||||
:::
|
:::
|
||||||
|
|
||||||
[^1]: cause why not, right!?
|
[^1]: cause why not, right!?
|
||||||
[^2]: except the bottom row
|
[^2]: except the bottom row
|
||||||
[^3]: definitely not an RHCP reference :wink:
|
[^3]: definitely not an RHCP reference :wink:
|
||||||
[^4]: one was not correct, thus the quotes
|
[^4]: one was not correct, thus the quotes
|
|
@ -4,9 +4,9 @@ title: Použití červeno-černých stromů
|
||||||
description: |
|
description: |
|
||||||
Ukázka použití červeno-černých stromů v standardních knižnicích známých jazyků.
|
Ukázka použití červeno-černých stromů v standardních knižnicích známých jazyků.
|
||||||
tags:
|
tags:
|
||||||
- balanced trees
|
- balanced trees
|
||||||
- red-black trees
|
- red-black trees
|
||||||
- applications
|
- applications
|
||||||
last_update:
|
last_update:
|
||||||
date: 2022-04-05
|
date: 2022-04-05
|
||||||
---
|
---
|
|
@ -4,8 +4,8 @@ title: On the rules of the red-black tree
|
||||||
description: |
|
description: |
|
||||||
Shower thoughts on the rules of the red-black tree.
|
Shower thoughts on the rules of the red-black tree.
|
||||||
tags:
|
tags:
|
||||||
- red-black trees
|
- red-black trees
|
||||||
- balanced trees
|
- balanced trees
|
||||||
last_update:
|
last_update:
|
||||||
date: 2023-06-10
|
date: 2023-06-10
|
||||||
---
|
---
|
||||||
|
@ -18,6 +18,7 @@ each of the red-black tree rules and try to change, break and contemplate about
|
||||||
them.
|
them.
|
||||||
|
|
||||||
We expect that you are familiar with the following set of the rules[^1]:
|
We expect that you are familiar with the following set of the rules[^1]:
|
||||||
|
|
||||||
1. Every node is either red or black.
|
1. Every node is either red or black.
|
||||||
2. The root is black.
|
2. The root is black.
|
||||||
3. Every leaf (`nil`) is black.
|
3. Every leaf (`nil`) is black.
|
||||||
|
@ -55,13 +56,13 @@ my child would be colored red.
|
||||||
Example of a red-black tree that keeps count of black nodes on paths to the
|
Example of a red-black tree that keeps count of black nodes on paths to the
|
||||||
leaves follows:
|
leaves follows:
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/b1fc8/b1fc85179faf0a17551a76a774a0be0003221e43" alt="Red-black tree with black height"
|
data:image/s3,"s3://crabby-images/df108/df108ad1ca61ac55f651cf76d7d865bee1473c73" alt="Red-black tree with black height"
|
||||||
data:image/s3,"s3://crabby-images/ae5b4/ae5b4aad5705c5baebdfaff6303514aba3ba7f88" alt="Red-black tree with black height"
|
data:image/s3,"s3://crabby-images/9c989/9c9899c7a77fd0a4a5279a32091c2262d97e9dfb" alt="Red-black tree with black height"
|
||||||
|
|
||||||
We mark the _black heights_ in superscript. You can see that all leaves have the
|
We mark the _black heights_ in superscript. You can see that all leaves have the
|
||||||
black height equal to $1$. Let's take a look at some of the interesting cases:
|
black height equal to $1$. Let's take a look at some of the interesting cases:
|
||||||
|
|
||||||
* If we take a look at the node with $\text{key} = 9$, we can see that it is
|
- If we take a look at the node with $\text{key} = 9$, we can see that it is
|
||||||
coloured red and its black height is 1, because it is a leaf.
|
coloured red and its black height is 1, because it is a leaf.
|
||||||
|
|
||||||
Let's look at its parent (node with $\text{key} = 8$). On its left side it has
|
Let's look at its parent (node with $\text{key} = 8$). On its left side it has
|
||||||
|
@ -71,12 +72,12 @@ black height equal to $1$. Let's take a look at some of the interesting cases:
|
||||||
We can clearly see that if a node has the same black height as its parent, it
|
We can clearly see that if a node has the same black height as its parent, it
|
||||||
is a red node.
|
is a red node.
|
||||||
|
|
||||||
* Now let's take a look at the root with $\text{key} = 3$. It has a black height
|
- Now let's take a look at the root with $\text{key} = 3$. It has a black height
|
||||||
of 3. Both of its children are black nodes and have black height of 2.
|
of 3. Both of its children are black nodes and have black height of 2.
|
||||||
|
|
||||||
We can see that if a node has its height 1 lower than its parent, it is a black
|
We can see that if a node has its height 1 lower than its parent, it is a black
|
||||||
node.
|
node.
|
||||||
|
|
||||||
The reasoning behind it is rather simple, we count the black nodes all the way
|
The reasoning behind it is rather simple, we count the black nodes all the way
|
||||||
to the leaves, therefore if my parent has a higher black height, it means that
|
to the leaves, therefore if my parent has a higher black height, it means that
|
||||||
on the path from me to my parent there is a black node, but the only node added
|
on the path from me to my parent there is a black node, but the only node added
|
||||||
|
@ -95,6 +96,7 @@ This rule might seem like a very important one, but overall is not. You can safe
|
||||||
omit this rule, but you also need to deal with the consequences.
|
omit this rule, but you also need to deal with the consequences.
|
||||||
|
|
||||||
Let's refresh our memory with the algorithm of _insert fixup_:
|
Let's refresh our memory with the algorithm of _insert fixup_:
|
||||||
|
|
||||||
```
|
```
|
||||||
WHILE z.p.color == Red
|
WHILE z.p.color == Red
|
||||||
IF z.p == z.p.p.left
|
IF z.p == z.p.p.left
|
||||||
|
@ -138,17 +140,17 @@ black root property.
|
||||||
If we decide to omit this condition, we need to address it in the pseudocodes
|
If we decide to omit this condition, we need to address it in the pseudocodes
|
||||||
accordingly.
|
accordingly.
|
||||||
|
|
||||||
| Usual algorithm with black root | Allowing red root |
|
| Usual algorithm with black root | Allowing red root |
|
||||||
| :-----------------------------: | :---------------: |
|
| :------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------: | :------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------: |
|
||||||
| data:image/s3,"s3://crabby-images/05ea9/05ea9dcfb734f6a6548b3831c038b447d03fa50f" alt="1ª insertion"data:image/s3,"s3://crabby-images/a4b20/a4b208510d766514a25f7b3eb2efce5d382d55ff" alt="1ª insertion" | data:image/s3,"s3://crabby-images/4f43c/4f43c0840e636ef1092d6cf3c265f7115d1c348a" alt="1ª insertion"data:image/s3,"s3://crabby-images/029cc/029cce8dd0a5afaaed7817cdb853df9c5aa00599" alt="1ª insertion" |
|
| data:image/s3,"s3://crabby-images/eecb8/eecb85f47a8e580f9ebf85ea03dbf52c3b24714c" alt="1ª insertion"data:image/s3,"s3://crabby-images/afa29/afa296c420a518919b2e938767f9988e5089746a" alt="1ª insertion" | data:image/s3,"s3://crabby-images/f3cf9/f3cf95a348eb98d34b0293638266b0e675fa2241" alt="1ª insertion"data:image/s3,"s3://crabby-images/18f20/18f20e37f8873a3529c9128e833db884cfd3a779" alt="1ª insertion" |
|
||||||
| data:image/s3,"s3://crabby-images/9a617/9a617696d665813c3d5c4c7652faac139dcecaee" alt="2ª insertion"data:image/s3,"s3://crabby-images/b044d/b044dcd1a3638e02395a99c8aab638549289afae" alt="2ª insertion" | data:image/s3,"s3://crabby-images/73b33/73b338982f2e06add1797d739668b61bcd6c8286" alt="2ª insertion"data:image/s3,"s3://crabby-images/be847/be847345d401bd3b3cfd87b96fdf769633f6caf7" alt="2ª insertion" |
|
| data:image/s3,"s3://crabby-images/94e81/94e81e56370f89640dcbb46c9bf8e1a7d03e3413" alt="2ª insertion"data:image/s3,"s3://crabby-images/6c202/6c2021746b0686f1794e63cc0c5e0babb602d1f8" alt="2ª insertion" | data:image/s3,"s3://crabby-images/c97ae/c97ae9b986035ce1f7db19e675d3c886fa759bb2" alt="2ª insertion"data:image/s3,"s3://crabby-images/3ec24/3ec24526ee024b6d6857a37d53f824cd2c0699b1" alt="2ª insertion" |
|
||||||
| data:image/s3,"s3://crabby-images/bb248/bb24836248202519f3ccb2522d24fa3a29a675e1" alt="3ª insertion"data:image/s3,"s3://crabby-images/29365/2936539a6cd8b024cb77c5b168fa2c6692664d87" alt="3ª insertion" | data:image/s3,"s3://crabby-images/5f695/5f69558c7dbf538d4cc4a2c6f9cd9652b61426ae" alt="3ª insertion"data:image/s3,"s3://crabby-images/c0ebd/c0ebdbbc77d9384bd53bc806ebb034c851f26cee" alt="3ª insertion" |
|
| data:image/s3,"s3://crabby-images/fd601/fd6015c6cf07d1c06e3371a4a4a392cb6cf42d49" alt="3ª insertion"data:image/s3,"s3://crabby-images/31463/3146350f4abf31cae5fc5c6f0589e18286c75f03" alt="3ª insertion" | data:image/s3,"s3://crabby-images/37764/377641781668c91c997ef79346affa8a8d3085a1" alt="3ª insertion"data:image/s3,"s3://crabby-images/ff3d1/ff3d14de43b7e783470996a79a3fd2c9a8230037" alt="3ª insertion" |
|
||||||
| data:image/s3,"s3://crabby-images/d9c0e/d9c0e464ca34b5b58acc6883e7c0d7e0f9bba22a" alt="4ª insertion"data:image/s3,"s3://crabby-images/da5c4/da5c4cad0e773ee0f2aff353a0b94c9a72260978" alt="4ª insertion" | data:image/s3,"s3://crabby-images/6a937/6a93745b85b1524d3384964666a53557cdb294c8" alt="4ª insertion"data:image/s3,"s3://crabby-images/91c8b/91c8b5e916ce53810512e8fca650bbf735cfd15d" alt="4ª insertion" |
|
| data:image/s3,"s3://crabby-images/3ff9d/3ff9d9ace1765a3a2712fac39a2998b82d427fd4" alt="4ª insertion"data:image/s3,"s3://crabby-images/ba544/ba54454ca72a8a1d0a61d3b4599dd709279be43d" alt="4ª insertion" | data:image/s3,"s3://crabby-images/f44dd/f44ddead0a56d3a7f389015c477d336adf22f510" alt="4ª insertion"data:image/s3,"s3://crabby-images/98c70/98c70e04a68e7ab2c9ba03eb5b6d493dbda250ae" alt="4ª insertion" |
|
||||||
| data:image/s3,"s3://crabby-images/476ea/476ea6ebf39b5b3fc7d29779bdd672cd03553d32" alt="5ª insertion"data:image/s3,"s3://crabby-images/fd732/fd732a4ea47acb1101db93e24d4ad513123a0234" alt="5ª insertion" | data:image/s3,"s3://crabby-images/a656a/a656ab52126fbb94c20678f0e2e805d3c40843b3" alt="5ª insertion"data:image/s3,"s3://crabby-images/fd820/fd820c0684f7055e33efb623cfb08f032ac35242" alt="5ª insertion" |
|
| data:image/s3,"s3://crabby-images/2c1e7/2c1e7b71391f73192be1318d77dc59c564baa0ca" alt="5ª insertion"data:image/s3,"s3://crabby-images/ae3c5/ae3c5327cb1a3e5246b783c1524d01d26ff74733" alt="5ª insertion" | data:image/s3,"s3://crabby-images/d3da0/d3da0cbe1716911661f000ed533db7335d18b889" alt="5ª insertion"data:image/s3,"s3://crabby-images/77015/77015ec8f61805dc2cc4e8fc35309a3284824d9c" alt="5ª insertion" |
|
||||||
| data:image/s3,"s3://crabby-images/dd3f5/dd3f55f85f78c8b8a6babce61df4216bd135457c" alt="6ª insertion"data:image/s3,"s3://crabby-images/877a0/877a090d71ae62076c77434f20766d06468c4176" alt="6ª insertion" | data:image/s3,"s3://crabby-images/d379b/d379bf3409540e4e596209886778fd7d6efddd83" alt="6ª insertion"data:image/s3,"s3://crabby-images/ca518/ca51875073c82950ebeddc7d97afe0d29a945c2a" alt="6ª insertion" |
|
| data:image/s3,"s3://crabby-images/6db6d/6db6d7f04f77c1eb3e84c9e964ecd1ae387c9422" alt="6ª insertion"data:image/s3,"s3://crabby-images/a8d2f/a8d2fd86cb15ebdfceaa2015db488cc187b1d967" alt="6ª insertion" | data:image/s3,"s3://crabby-images/848dc/848dc4d72aa235edb9456096caa9ce7e821a5898" alt="6ª insertion"data:image/s3,"s3://crabby-images/47fe3/47fe3175913a8b4502fdf0ba34b04c6aaff34ab7" alt="6ª insertion" |
|
||||||
| data:image/s3,"s3://crabby-images/75884/7588479883def2a89ac25554d2da1e80d7f91449" alt="7ª insertion"data:image/s3,"s3://crabby-images/55eb0/55eb08255765468c351c295e13b86720bb47c1d3" alt="7ª insertion" | data:image/s3,"s3://crabby-images/10f13/10f13c236f6d0e3e8ba3f7d54a0e9acd08330879" alt="7ª insertion"data:image/s3,"s3://crabby-images/9698d/9698d90447f166f5db7e21d974a64e7a98ecfc88" alt="7ª insertion" |
|
| data:image/s3,"s3://crabby-images/92601/926016a9197a9c9454e1adb8dea1f0f4799c2b21" alt="7ª insertion"data:image/s3,"s3://crabby-images/3eb77/3eb77402f065ae56032746911eba67eb5c3548c0" alt="7ª insertion" | data:image/s3,"s3://crabby-images/7c17e/7c17ea79d7e0bd95bef9dafc75ec7f9012601f2a" alt="7ª insertion"data:image/s3,"s3://crabby-images/fe222/fe2221356d028c6f8d1f2d7c51b1ff12d5ba60cc" alt="7ª insertion" |
|
||||||
| data:image/s3,"s3://crabby-images/bfc02/bfc020e80981741ebd6d20ad01ae1cd9101dca99" alt="8ª insertion"data:image/s3,"s3://crabby-images/79947/79947d982324c1ad7ed2456478b3d54c2806a073" alt="8ª insertion" | data:image/s3,"s3://crabby-images/6fb4c/6fb4cb3ccf4ed96b7e10e8799ddfee0e003270cf" alt="8ª insertion"data:image/s3,"s3://crabby-images/af00c/af00cf3bc5c283afeae27bd3af23ef017809dde5" alt="8ª insertion" |
|
| data:image/s3,"s3://crabby-images/317e5/317e5bc2b7274ae8aa35de289c19190c69ba360c" alt="8ª insertion"data:image/s3,"s3://crabby-images/66149/66149db648bf0ef3cbf59363b9c7171b07de0987" alt="8ª insertion" | data:image/s3,"s3://crabby-images/44e0e/44e0e8e96390c1e1ddfe4a3aa885bb1fd6533eb7" alt="8ª insertion"data:image/s3,"s3://crabby-images/adc99/adc993e521dfb57b57859677d75ff7a7749987e4" alt="8ª insertion" |
|
||||||
| data:image/s3,"s3://crabby-images/4ea81/4ea814d25f2cb9915aef4e400d261fd9e555e699" alt="9ª insertion"data:image/s3,"s3://crabby-images/99515/9951539835591dbdd655d5e8aa7971f9d81a0b81" alt="9ª insertion" | data:image/s3,"s3://crabby-images/7fe33/7fe332a9c9150691c294a7efacc658b15804c246" alt="9ª insertion"data:image/s3,"s3://crabby-images/1b3f2/1b3f2296d4b152a238b9f0d507f1b0e01b329813" alt="9ª insertion" |
|
| data:image/s3,"s3://crabby-images/72fef/72fefa0e69d47c5be2144b3232bc76aa2b1997cb" alt="9ª insertion"data:image/s3,"s3://crabby-images/49fee/49feeffa10c8526bddd44df1fb1d1158bebc3d0c" alt="9ª insertion" | data:image/s3,"s3://crabby-images/97dc0/97dc037001031b913ff3b719e07a728bbef4e716" alt="9ª insertion"data:image/s3,"s3://crabby-images/7ca9c/7ca9ccafee461e1558ff6bd3a7bcdeb60f5a5cc4" alt="9ª insertion" |
|
||||||
|
|
||||||
## 3ª Every leaf (`nil`) is black.
|
## 3ª Every leaf (`nil`) is black.
|
||||||
|
|
||||||
|
@ -157,8 +159,8 @@ some other way? Let's go through some of the possible ways I can look at this an
|
||||||
how would they affect the other rules and balancing.
|
how would they affect the other rules and balancing.
|
||||||
|
|
||||||
We will experiment with the following tree:
|
We will experiment with the following tree:
|
||||||
data:image/s3,"s3://crabby-images/5b814/5b81470965f6af1f92686b7b0d0d088780ddb54b" alt=""
|
data:image/s3,"s3://crabby-images/6907e/6907e30efffe34ffe9a7f9ddd0a78607a707d09c" alt=""
|
||||||
data:image/s3,"s3://crabby-images/ce03b/ce03b39fbe297334f3de41c25fffc0a75531b06d" alt=""
|
data:image/s3,"s3://crabby-images/a55e4/a55e4bf6cdbc40295a18ca47e4450f6469622260" alt=""
|
||||||
|
|
||||||
We should start by counting the black nodes from root to the `nil` leaves based
|
We should start by counting the black nodes from root to the `nil` leaves based
|
||||||
on the rules. We have multiple similar paths, so we will pick only the interesting
|
on the rules. We have multiple similar paths, so we will pick only the interesting
|
||||||
|
@ -170,11 +172,11 @@ ones.
|
||||||
3. What happens if we do not count the `nil` leaves, but consider nodes with at
|
3. What happens if we do not count the `nil` leaves, but consider nodes with at
|
||||||
least one `nil` descendant as leaves?
|
least one `nil` descendant as leaves?
|
||||||
|
|
||||||
| path | black nodes | 1ª idea | 2ª idea | 3ª idea |
|
| path | black nodes | 1ª idea | 2ª idea | 3ª idea |
|
||||||
| ------------------------: | ----------: | ------: | ------: | ------: |
|
| ------------------------: | ----------: | ------: | ------: | ------: |
|
||||||
| `3 → 1 → 0 → nil` | 4 | 3 | 4 | 3 |
|
| `3 → 1 → 0 → nil` | 4 | 3 | 4 | 3 |
|
||||||
| `3 → 5 → 7 → 8 → nil` | 4 | 3 | - | 3 |
|
| `3 → 5 → 7 → 8 → nil` | 4 | 3 | - | 3 |
|
||||||
| `3 → 5 → 7 → 8 → 9 → nil` | 4 | 3 | 4 | 3 |
|
| `3 → 5 → 7 → 8 → 9 → nil` | 4 | 3 | 4 | 3 |
|
||||||
|
|
||||||
First idea is very easy to execute and it is also very easy to argue about its
|
First idea is very easy to execute and it is also very easy to argue about its
|
||||||
correctness. It is correct, because we just subtract one from each of the paths.
|
correctness. It is correct, because we just subtract one from each of the paths.
|
||||||
|
@ -208,7 +210,7 @@ functions:
|
||||||
|
|
||||||
When we have a look at the algorithms that are used for fixing up the red-black
|
When we have a look at the algorithms that are used for fixing up the red-black
|
||||||
tree after an insertion or deletion, we will notice that all the algorithms need
|
tree after an insertion or deletion, we will notice that all the algorithms need
|
||||||
is the color of the node.
|
is the color of the node.
|
||||||
|
|
||||||
> How come it is the only thing that we need?
|
> How come it is the only thing that we need?
|
||||||
> How come such naïve thing can be enough?
|
> How come such naïve thing can be enough?
|
||||||
|
@ -232,15 +234,15 @@ import TabItem from '@theme/TabItem';
|
||||||
<Tabs>
|
<Tabs>
|
||||||
<TabItem value="enforcing" label="Enforcing this rule">
|
<TabItem value="enforcing" label="Enforcing this rule">
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/ff48d/ff48d716bc6f81e5314d3013bc98d773d7d550b2" alt=""
|
data:image/s3,"s3://crabby-images/591f6/591f6a7279547c3aa7d615f9b8d96a2e097e78e7" alt=""
|
||||||
data:image/s3,"s3://crabby-images/fd81a/fd81a9fc95dc413ea11663dee2add149b3a12166" alt=""
|
data:image/s3,"s3://crabby-images/54dd7/54dd742bf74db3e5fbdb72d03c335f9314bc2297" alt=""
|
||||||
|
|
||||||
</TabItem>
|
</TabItem>
|
||||||
|
|
||||||
<TabItem value="omitting" label="Omitting this rule">
|
<TabItem value="omitting" label="Omitting this rule">
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/28ebe/28ebe8ae6cdff5a99438f69dd0ffec0bafea8673" alt=""
|
data:image/s3,"s3://crabby-images/39cc2/39cc2523ca75d5f369992ad4e0c44e3d4c9777ff" alt=""
|
||||||
data:image/s3,"s3://crabby-images/06de0/06de06d9f50d0ee550828dc7f685f48e4bb7577d" alt=""
|
data:image/s3,"s3://crabby-images/1079e/1079eaa305915638a16929c3ec6c0b710ac44f69" alt=""
|
||||||
|
|
||||||
</TabItem>
|
</TabItem>
|
||||||
</Tabs>
|
</Tabs>
|
||||||
|
@ -262,6 +264,7 @@ An important observation here is the fact that the red-black tree is a
|
||||||
:::
|
:::
|
||||||
|
|
||||||
Enforcing this rule (together with the 4th rule) keeps the tree balanced:
|
Enforcing this rule (together with the 4th rule) keeps the tree balanced:
|
||||||
|
|
||||||
1. 4th rule makes sure we can't “hack” this requirement.
|
1. 4th rule makes sure we can't “hack” this requirement.
|
||||||
2. This rule ensures that we have “similar”[^2] length to each of the leaves.
|
2. This rule ensures that we have “similar”[^2] length to each of the leaves.
|
||||||
|
|
||||||
|
@ -279,4 +282,4 @@ complexity for the operations, but having more relaxed rules.
|
||||||
:::
|
:::
|
||||||
|
|
||||||
[^1]: CORMEN, Thomas. Introduction to algorithms. Cambridge, Mass: MIT Press, 2009. isbn 9780262033848.
|
[^1]: CORMEN, Thomas. Introduction to algorithms. Cambridge, Mass: MIT Press, 2009. isbn 9780262033848.
|
||||||
[^2]: red nodes still exist
|
[^2]: red nodes still exist
|
|
@ -4,17 +4,17 @@ title: Iterative algorithms via iterators
|
||||||
description: |
|
description: |
|
||||||
Iterative DFS using iterators.
|
Iterative DFS using iterators.
|
||||||
tags:
|
tags:
|
||||||
- csharp
|
- csharp
|
||||||
- graphs
|
- graphs
|
||||||
- iterators
|
- iterators
|
||||||
- iterative
|
- iterative
|
||||||
last_update:
|
last_update:
|
||||||
date: 2021-05-18
|
date: 2021-05-18
|
||||||
---
|
---
|
||||||
|
|
||||||
## Introduction
|
## Introduction
|
||||||
|
|
||||||
- [Source code used later on.](pathname:///files/ib002/graphs/iterative-and-iterators.tar.gz)
|
- [Source code used later on.](pathname:///files/algorithms/graphs/iterative-and-iterators.tar.gz)
|
||||||
|
|
||||||
As we have talked on the seminar, iterative approach to implementing DFS is not very intuitive and is a very easy way how to create an incorrect implementation.
|
As we have talked on the seminar, iterative approach to implementing DFS is not very intuitive and is a very easy way how to create an incorrect implementation.
|
||||||
|
|
||||||
|
@ -171,7 +171,6 @@ begin
|
||||||
end DFS;
|
end DFS;
|
||||||
```
|
```
|
||||||
|
|
||||||
|
|
||||||
( The way we manipulate with the iterators is closest to the C# implementation. Apart from the `Iterator` thing :) In case you tried to implement it in C++, you would more than likely need to change the check, since you would get first successor right at the beginning )
|
( The way we manipulate with the iterators is closest to the C# implementation. Apart from the `Iterator` thing :) In case you tried to implement it in C++, you would more than likely need to change the check, since you would get first successor right at the beginning )
|
||||||
|
|
||||||
So here we don't keep indices, but the iterators. We can also check existence of other successors easily: by the iterator moving after the last successor.
|
So here we don't keep indices, but the iterators. We can also check existence of other successors easily: by the iterator moving after the last successor.
|
|
@ -4,8 +4,8 @@ title: Distance boundaries from BFS tree on undirected graphs
|
||||||
description: |
|
description: |
|
||||||
Short explanation of distance boundaries deduced from a BFS tree.
|
Short explanation of distance boundaries deduced from a BFS tree.
|
||||||
tags:
|
tags:
|
||||||
- graphs
|
- graphs
|
||||||
- bfs
|
- bfs
|
||||||
last_update:
|
last_update:
|
||||||
date: 2022-04-30
|
date: 2022-04-30
|
||||||
---
|
---
|
||||||
|
@ -21,13 +21,13 @@ As we have talked on the seminar, if we construct from some vertex $u$ BFS tree
|
||||||
|
|
||||||
Consider the following graph:
|
Consider the following graph:
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/d2cd4/d2cd461e90ef57e375aa13ac84f8d4d6db439829" alt=""
|
data:image/s3,"s3://crabby-images/456f8/456f8d499e8c53cf7725505f4fa22640eb23bac1" alt=""
|
||||||
data:image/s3,"s3://crabby-images/c2480/c248011577d86953c34bf98c5d7fb8a493d70fd4" alt=""
|
data:image/s3,"s3://crabby-images/9006b/9006b6db2269d364d9c89374c44fa31665df3bfe" alt=""
|
||||||
|
|
||||||
We run BFS from the vertex $a$ and obtain the following BFS tree:
|
We run BFS from the vertex $a$ and obtain the following BFS tree:
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/df621/df621bd3f67d8957a3fe9d6334de1514310f6c44" alt=""
|
data:image/s3,"s3://crabby-images/96b4f/96b4f6c7adff116dba47412f9004c02780490190" alt=""
|
||||||
data:image/s3,"s3://crabby-images/0b428/0b4289a64a1f29a026e6d10c70b77f4940e2b8ef" alt=""
|
data:image/s3,"s3://crabby-images/fd4b6/fd4b66c44d059a77a8ccd5429db4a3b8c255fba5" alt=""
|
||||||
|
|
||||||
Let's consider pair of vertices $e$ and $h$. For them we can safely lay, from the BFS tree, following properties:
|
Let's consider pair of vertices $e$ and $h$. For them we can safely lay, from the BFS tree, following properties:
|
||||||
|
|
||||||
|
@ -42,9 +42,8 @@ Let's keep the same graph, but break the lower bound, i.e. I have gotten a lower
|
||||||
|
|
||||||
Now the more important question, is there a shorter path in that graph? The answer is no, there's no shorter path than the one with length $2$. So what can we do about it? We'll add an edge to have a shorter path. Now we have gotten a lower bound of $2$, which means the only shorter path we can construct has $1$ edge and that is ‹$e, h$› (no intermediary vertices). Let's do this!
|
Now the more important question, is there a shorter path in that graph? The answer is no, there's no shorter path than the one with length $2$. So what can we do about it? We'll add an edge to have a shorter path. Now we have gotten a lower bound of $2$, which means the only shorter path we can construct has $1$ edge and that is ‹$e, h$› (no intermediary vertices). Let's do this!
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/c1f23/c1f2367372bd08de1868ca26f324810de3b0f550" alt=""
|
data:image/s3,"s3://crabby-images/226d2/226d268142cdc555a2fef1c6a12a7c520de78197" alt=""
|
||||||
data:image/s3,"s3://crabby-images/62d52/62d52da1390cb5fbdbe49dd0dd75306a184bddfa" alt=""
|
data:image/s3,"s3://crabby-images/541d8/541d812ecfdbb4e87459a38dfc10f23c3e6700cb" alt=""
|
||||||
|
|
||||||
|
|
||||||
Okay, so we have a graph that breaks the rule we have laid. However, we need to run BFS to obtain the new BFS tree, since we have changed the graph.
|
Okay, so we have a graph that breaks the rule we have laid. However, we need to run BFS to obtain the new BFS tree, since we have changed the graph.
|
||||||
|
|
||||||
|
@ -56,8 +55,8 @@ Do we need to run BFS after **every** change?
|
||||||
|
|
||||||
:::
|
:::
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/4528e/4528e77e1d383171d74b262e741942e8298978ed" alt=""
|
data:image/s3,"s3://crabby-images/9249f/9249fc15e49003544a8da11ca23bb06d173d246f" alt=""
|
||||||
data:image/s3,"s3://crabby-images/3d370/3d370a2216ba06297f788c220c0dc6f3a141496d" alt=""
|
data:image/s3,"s3://crabby-images/0cba3/0cba31daaf236adc8fd56e44351e87e644b720b1" alt=""
|
||||||
|
|
||||||
Oops, we have gotten a new BFS tree, that has a height difference of 1.
|
Oops, we have gotten a new BFS tree, that has a height difference of 1.
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
---
|
---
|
||||||
id: ib015-intro
|
id: automata-intro
|
||||||
title: Introduction
|
title: Introduction
|
||||||
slug: /
|
slug: /
|
||||||
---
|
---
|
|
@ -1,5 +1,5 @@
|
||||||
---
|
---
|
||||||
id: ib111-intro
|
id: c-intro
|
||||||
title: Introduction
|
title: Introduction
|
||||||
slug: /
|
slug: /
|
||||||
---
|
---
|
|
@ -30,7 +30,7 @@ Details can be found in the doxygen comments included in the source files.
|
||||||
|
|
||||||
## Light version (`main_light.c`)
|
## Light version (`main_light.c`)
|
||||||
|
|
||||||
[Source](pathname:///files/pb071/bonuses/03/main_light.c)
|
[Source](pathname:///files/c/bonuses/03/main_light.c)
|
||||||
|
|
||||||
For the light version you have 3 functions to finish:
|
For the light version you have 3 functions to finish:
|
||||||
|
|
||||||
|
@ -40,7 +40,7 @@ For the light version you have 3 functions to finish:
|
||||||
|
|
||||||
## Full fat version (`main.c`)
|
## Full fat version (`main.c`)
|
||||||
|
|
||||||
[Source](pathname:///files/pb071/bonuses/03/main.c)
|
[Source](pathname:///files/c/bonuses/03/main.c)
|
||||||
|
|
||||||
For the full fat version you have 4 functions to implement:
|
For the full fat version you have 4 functions to implement:
|
||||||
|
|
||||||
|
@ -61,6 +61,7 @@ passed a _function pointer_ to the comparator that you use for comparing the
|
||||||
respective elements in the passed in array.
|
respective elements in the passed in array.
|
||||||
|
|
||||||
If we take the parameter from one of the functions from the skeleton:
|
If we take the parameter from one of the functions from the skeleton:
|
||||||
|
|
||||||
```c
|
```c
|
||||||
int (*comp)(const void *, const void *)
|
int (*comp)(const void *, const void *)
|
||||||
```
|
```
|
||||||
|
@ -91,6 +92,7 @@ Ideally create a directory `seminar-bonuses` in the root of your repository with
|
||||||
bonuses in their own subdirectories.
|
bonuses in their own subdirectories.
|
||||||
|
|
||||||
Structure of your repository can look like this:
|
Structure of your repository can look like this:
|
||||||
|
|
||||||
```
|
```
|
||||||
.
|
.
|
||||||
├── bonuses
|
├── bonuses
|
|
@ -22,7 +22,7 @@ or just by submitting an issue [here](https://gitlab.fi.muni.cz/xfocko/kb/-/issu
|
||||||
|
|
||||||
For this bonus you can get 3 K₡ and another 0.5 K₡ for the bonus part of it.
|
For this bonus you can get 3 K₡ and another 0.5 K₡ for the bonus part of it.
|
||||||
|
|
||||||
[Source](pathname:///files/pb071/bonuses/04.tar.gz)
|
[Source](pathname:///files/c/bonuses/04.tar.gz)
|
||||||
|
|
||||||
## Introduction
|
## Introduction
|
||||||
|
|
|
@ -7,7 +7,7 @@ description: |
|
||||||
|
|
||||||
For this bonus you can get at maximum 2.5 K₡.
|
For this bonus you can get at maximum 2.5 K₡.
|
||||||
|
|
||||||
[Source](pathname:///files/pb071/bonuses/05-06.tar.gz)
|
[Source](pathname:///files/c/bonuses/05-06.tar.gz)
|
||||||
|
|
||||||
## Introduction
|
## Introduction
|
||||||
|
|
|
@ -7,7 +7,7 @@ description: |
|
||||||
|
|
||||||
# 8th seminar bonus assignment
|
# 8th seminar bonus assignment
|
||||||
|
|
||||||
[Source](pathname:///files/pb071/bonuses/08.tar.gz)
|
[Source](pathname:///files/c/bonuses/08.tar.gz)
|
||||||
|
|
||||||
## Introduction
|
## Introduction
|
||||||
|
|
||||||
|
@ -118,7 +118,7 @@ nil
|
||||||
</td>
|
</td>
|
||||||
<td>
|
<td>
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/f590d/f590de6a04f28ec61487198d65557fc95329db7e" alt="tree"
|
data:image/s3,"s3://crabby-images/1cb19/1cb19d5f3c0c26dc9cd37cf7d1dff2efc6dfe3e7" alt="tree"
|
||||||
|
|
||||||
</td>
|
</td>
|
||||||
</tr></table>
|
</tr></table>
|
|
@ -5,7 +5,7 @@ description: |
|
||||||
Finding bugs in a hangman.
|
Finding bugs in a hangman.
|
||||||
---
|
---
|
||||||
|
|
||||||
[Source](pathname:///files/pb071/bonuses/10.tar.gz)
|
[Source](pathname:///files/c/bonuses/10.tar.gz)
|
||||||
|
|
||||||
## Introduction
|
## Introduction
|
||||||
|
|
||||||
|
@ -86,7 +86,7 @@ As we have talked about on the seminar, I suggest you to follow
|
||||||
_Test-Driven Development_
|
_Test-Driven Development_
|
||||||
in this case.
|
in this case.
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/d5811/d581178a0f668e0e541f20077ed333f6b0dc4648" alt="TDD workflow"
|
data:image/s3,"s3://crabby-images/60e64/60e64981443c6d19367cf3d98040354ce2dda675" alt="TDD workflow"
|
||||||
|
|
||||||
In our current scenario we are already in the stage of refactoring and fixing the
|
In our current scenario we are already in the stage of refactoring and fixing the
|
||||||
bugs. Therefore try to follow this succession of steps:
|
bugs. Therefore try to follow this succession of steps:
|
|
@ -11,16 +11,16 @@ last_update:
|
||||||
|
|
||||||
:::caution Exam environment
|
:::caution Exam environment
|
||||||
|
|
||||||
* During the exam you will be provided with a barebone _exam session_ on the
|
- During the exam you will be provided with a barebone _exam session_ on the
|
||||||
_faculty computers_.
|
_faculty computers_.
|
||||||
* In browser you are only allowed to have the following tabs open:
|
- In browser you are only allowed to have the following tabs open:
|
||||||
* [C documentation](https://en.cppreference.com)
|
- [C documentation](https://en.cppreference.com)
|
||||||
* page containing the assignment
|
- page containing the assignment
|
||||||
* You **are not** allowed to use your own source code, e.g. prepared beforehand
|
- You **are not** allowed to use your own source code, e.g. prepared beforehand
|
||||||
or from the seminars.
|
or from the seminars.
|
||||||
* You have **5 minutes** to read through the assignment and ask any follow-up
|
- You have **5 minutes** to read through the assignment and ask any follow-up
|
||||||
questions should be there something unclear.
|
questions should be there something unclear.
|
||||||
* You have **60 minutes** to work on the assignment, afterward your work will be
|
- You have **60 minutes** to work on the assignment, afterward your work will be
|
||||||
discussed with your seminar tutor.
|
discussed with your seminar tutor.
|
||||||
|
|
||||||
:::
|
:::
|
||||||
|
@ -41,11 +41,12 @@ can see only two commands being used:
|
||||||
1. `cd ‹somewhere›` that changes the current working directory.
|
1. `cd ‹somewhere›` that changes the current working directory.
|
||||||
|
|
||||||
At the beginning you start in the root of the filesystem (i.e. `/`).
|
At the beginning you start in the root of the filesystem (i.e. `/`).
|
||||||
|
|
||||||
You are **guaranteed** that `‹somewhere›` is:
|
You are **guaranteed** that `‹somewhere›` is:
|
||||||
* `.` that is a current working directory (i.e. does nothing),
|
|
||||||
* `..` that moves you up one level (in case you are in `/`, does nothing), or
|
- `.` that is a current working directory (i.e. does nothing),
|
||||||
* is a valid directory in the current working directory.
|
- `..` that moves you up one level (in case you are in `/`, does nothing), or
|
||||||
|
- is a valid directory in the current working directory.
|
||||||
|
|
||||||
:::caution
|
:::caution
|
||||||
|
|
||||||
|
@ -87,6 +88,7 @@ $ ls
|
||||||
```
|
```
|
||||||
|
|
||||||
For this input, you will get following file system:
|
For this input, you will get following file system:
|
||||||
|
|
||||||
```
|
```
|
||||||
- / (dir, size=48381165)
|
- / (dir, size=48381165)
|
||||||
- a (dir, size=94853)
|
- a (dir, size=94853)
|
||||||
|
@ -108,14 +110,14 @@ For this input, you will get following file system:
|
||||||
|
|
||||||
Your program should support 2 switches:
|
Your program should support 2 switches:
|
||||||
|
|
||||||
* `-gt ‹min_size›` that will print out suspiciously big files.
|
- `-gt ‹min_size›` that will print out suspiciously big files.
|
||||||
* `-f ‹total_size› ‹min_unused›` that will print out a file to be deleted.
|
- `-f ‹total_size› ‹min_unused›` that will print out a file to be deleted.
|
||||||
|
|
||||||
### `-gt ‹min_size›`
|
### `-gt ‹min_size›`
|
||||||
|
|
||||||
With this switch you are provided one additional argument:
|
With this switch you are provided one additional argument:
|
||||||
|
|
||||||
* `min_size` that is the lower bound (inclusive) for size of any file or
|
- `min_size` that is the lower bound (inclusive) for size of any file or
|
||||||
directory that is supposed to be listed.
|
directory that is supposed to be listed.
|
||||||
|
|
||||||
When your program is being run with this switch, it is is supposed to print out
|
When your program is being run with this switch, it is is supposed to print out
|
||||||
|
@ -125,13 +127,14 @@ all files **and** directories that are bigger than the provided `min_size`.
|
||||||
|
|
||||||
With this switch you are provided two additional arguments:
|
With this switch you are provided two additional arguments:
|
||||||
|
|
||||||
* `total_size` that is a total size of the filesystem[^2].
|
- `total_size` that is a total size of the filesystem[^2].
|
||||||
* `min_unused` that is a minimum of free space required for an upgrade.
|
- `min_unused` that is a minimum of free space required for an upgrade.
|
||||||
|
|
||||||
Your program should find **exactly one** file or a directory that is of the
|
Your program should find **exactly one** file or a directory that is of the
|
||||||
smallest size, but big enough to free enough space for the upgrade to proceed.
|
smallest size, but big enough to free enough space for the upgrade to proceed.
|
||||||
|
|
||||||
In other words, if that file or directory is deleted, following should hold:
|
In other words, if that file or directory is deleted, following should hold:
|
||||||
|
|
||||||
$$
|
$$
|
||||||
\mathtt{total\_size} - \mathtt{used} \geq \mathtt{min\_unused}
|
\mathtt{total\_size} - \mathtt{used} \geq \mathtt{min\_unused}
|
||||||
$$
|
$$
|
||||||
|
@ -151,19 +154,19 @@ program from the shell like
|
||||||
|
|
||||||
## Requirements and notes
|
## Requirements and notes
|
||||||
|
|
||||||
* Define **structures** (and **enumerations**, if applicable) for the parsed
|
- Define **structures** (and **enumerations**, if applicable) for the parsed
|
||||||
information from the files.
|
information from the files.
|
||||||
* For keeping the “records”, use some **dynamic** data structure.
|
- For keeping the “records”, use some **dynamic** data structure.
|
||||||
* Don't forget to consider pros and cons of using _specific_ data structures
|
- Don't forget to consider pros and cons of using _specific_ data structures
|
||||||
before going through implementing.
|
before going through implementing.
|
||||||
* You **are not required** to produce 1:1 output to the provided examples, they
|
- You **are not required** to produce 1:1 output to the provided examples, they
|
||||||
are just a hint to not waste your time tinkering with a user experience.
|
are just a hint to not waste your time tinkering with a user experience.
|
||||||
* If any of the operations on the input files should fail,
|
- If any of the operations on the input files should fail,
|
||||||
**you are expected to** handle the situation _accordingly_.
|
**you are expected to** handle the situation _accordingly_.
|
||||||
* Failures of any other common functions (e.g. functions used for memory
|
- Failures of any other common functions (e.g. functions used for memory
|
||||||
management) should be handled in **the same way** as they were in the
|
management) should be handled in **the same way** as they were in the
|
||||||
homeworks and seminars.
|
homeworks and seminars.
|
||||||
* Your program **must free** all the resources before exiting.
|
- Your program **must free** all the resources before exiting.
|
||||||
|
|
||||||
[^1]: Also applies to Fedora, but… we use arch btw :wink:
|
[^1]: Also applies to Fedora, but… we use arch btw :wink:
|
||||||
[^2]: duh!
|
[^2]: duh!
|
|
@ -11,16 +11,16 @@ last_update:
|
||||||
|
|
||||||
:::caution Exam environment
|
:::caution Exam environment
|
||||||
|
|
||||||
* During the exam you will be provided with a barebone _exam session_ on the
|
- During the exam you will be provided with a barebone _exam session_ on the
|
||||||
_faculty computers_.
|
_faculty computers_.
|
||||||
* In browser you are only allowed to have the following tabs open:
|
- In browser you are only allowed to have the following tabs open:
|
||||||
* [C documentation](https://en.cppreference.com)
|
- [C documentation](https://en.cppreference.com)
|
||||||
* page containing the assignment
|
- page containing the assignment
|
||||||
* You **are not** allowed to use your own source code, e.g. prepared beforehand
|
- You **are not** allowed to use your own source code, e.g. prepared beforehand
|
||||||
or from the seminars.
|
or from the seminars.
|
||||||
* You have **5 minutes** to read through the assignment and ask any follow-up
|
- You have **5 minutes** to read through the assignment and ask any follow-up
|
||||||
questions should be there something unclear.
|
questions should be there something unclear.
|
||||||
* You have **60 minutes** to work on the assignment, afterward your work will be
|
- You have **60 minutes** to work on the assignment, afterward your work will be
|
||||||
discussed with your seminar tutor.
|
discussed with your seminar tutor.
|
||||||
|
|
||||||
:::
|
:::
|
||||||
|
@ -31,11 +31,11 @@ print out summary based on the input data. Your contributions to the society are
|
||||||
very much appreciated and may (or may not) be used for (each or none) of the
|
very much appreciated and may (or may not) be used for (each or none) of the
|
||||||
following purposes[^1]:
|
following purposes[^1]:
|
||||||
|
|
||||||
* stalking people leaving and coming back home,
|
- stalking people leaving and coming back home,
|
||||||
* retroactively making people pay for the parking,
|
- retroactively making people pay for the parking,
|
||||||
* providing evidence of people speeding on highways,
|
- providing evidence of people speeding on highways,
|
||||||
* tracking people that don't pay tolls, or
|
- tracking people that don't pay tolls, or
|
||||||
* convict employees leaving the work prematurely.
|
- convict employees leaving the work prematurely.
|
||||||
|
|
||||||
## Format of the input file
|
## Format of the input file
|
||||||
|
|
||||||
|
@ -45,10 +45,10 @@ specify `-` (i.e. `stdin`) as the path.
|
||||||
|
|
||||||
Each “scan” (i.e. reading) of the cameras consists of the following data:
|
Each “scan” (i.e. reading) of the cameras consists of the following data:
|
||||||
|
|
||||||
* _camera ID_: non-negative integer identifying a camera
|
- _camera ID_: non-negative integer identifying a camera
|
||||||
* _plate_: string of unknown length that can consist of any characters apart
|
- _plate_: string of unknown length that can consist of any characters apart
|
||||||
from whitespace
|
from whitespace
|
||||||
* _timestamp_: date and time of the scan as an unsigned integer (represented as
|
- _timestamp_: date and time of the scan as an unsigned integer (represented as
|
||||||
a UNIX time)
|
a UNIX time)
|
||||||
|
|
||||||
:::tip
|
:::tip
|
||||||
|
@ -114,7 +114,6 @@ when outputting the date and time.
|
||||||
|
|
||||||
:::
|
:::
|
||||||
|
|
||||||
|
|
||||||
:::tip
|
:::tip
|
||||||
|
|
||||||
For a better readability you can include one more newline after the last line
|
For a better readability you can include one more newline after the last line
|
||||||
|
@ -133,46 +132,46 @@ And it will produce an output:
|
||||||
|
|
||||||
*** ABC-12-34 ***
|
*** ABC-12-34 ***
|
||||||
25: Fri Oct 1 10:50:56 2021
|
25: Fri Oct 1 10:50:56 2021
|
||||||
|
|
||||||
10: Sat Oct 1 09:18:32 2022
|
10: Sat Oct 1 09:18:32 2022
|
||||||
16: Sat Oct 1 09:23:32 2022
|
16: Sat Oct 1 09:23:32 2022
|
||||||
|
|
||||||
19: Sat Oct 1 23:27:29 2022
|
19: Sat Oct 1 23:27:29 2022
|
||||||
|
|
||||||
*** EL9-987 ***
|
*** EL9-987 ***
|
||||||
11: Thu Mar 23 04:15:38 2023
|
11: Thu Mar 23 04:15:38 2023
|
||||||
|
|
||||||
*** Foo-666 ***
|
*** Foo-666 ***
|
||||||
2: Thu May 4 05:14:42 2023
|
2: Thu May 4 05:14:42 2023
|
||||||
|
|
||||||
*** TryToCatchMe ***
|
*** TryToCatchMe ***
|
||||||
42: Wed Dec 21 07:00:19 2022
|
42: Wed Dec 21 07:00:19 2022
|
||||||
42: Wed Dec 21 07:00:19 2022
|
42: Wed Dec 21 07:00:19 2022
|
||||||
1234: Wed Dec 21 07:00:19 2022
|
1234: Wed Dec 21 07:00:19 2022
|
||||||
|
|
||||||
*** XYZ-98-76 ***
|
*** XYZ-98-76 ***
|
||||||
289: Mon Oct 10 17:40:17 2022
|
289: Mon Oct 10 17:40:17 2022
|
||||||
|
|
||||||
*** YouShould-not-pLaCe-4ny-expectations%on^the(input ***
|
*** YouShould-not-pLaCe-4ny-expectations%on^the(input ***
|
||||||
69: Sat Apr 1 02:13:14 2023
|
69: Sat Apr 1 02:13:14 2023
|
||||||
|
|
||||||
*** YourMum ***
|
*** YourMum ***
|
||||||
42: Thu May 4 05:14:42 2023
|
42: Thu May 4 05:14:42 2023
|
||||||
|
|
||||||
## Requirements and notes
|
## Requirements and notes
|
||||||
|
|
||||||
* Define **structures** (and **enumerations**, if applicable) for the parsed
|
- Define **structures** (and **enumerations**, if applicable) for the parsed
|
||||||
information from the files.
|
information from the files.
|
||||||
* For keeping the “records”, use some **dynamic** data structure.
|
- For keeping the “records”, use some **dynamic** data structure.
|
||||||
* Don't forget to consider pros and cons of using _specific_ data structures
|
- Don't forget to consider pros and cons of using _specific_ data structures
|
||||||
before going through implementing.
|
before going through implementing.
|
||||||
* You **are not required** to produce 1:1 output to the provided examples, they
|
- You **are not required** to produce 1:1 output to the provided examples, they
|
||||||
are just a hint to not waste your time tinkering with a user experience.
|
are just a hint to not waste your time tinkering with a user experience.
|
||||||
* If any of the operations on the input files should fail,
|
- If any of the operations on the input files should fail,
|
||||||
**you are expected to** handle the situation _accordingly_.
|
**you are expected to** handle the situation _accordingly_.
|
||||||
* Failures of any other common functions (e.g. functions used for memory
|
- Failures of any other common functions (e.g. functions used for memory
|
||||||
management) should be handled in **the same way** as they were in the
|
management) should be handled in **the same way** as they were in the
|
||||||
homeworks and seminars.
|
homeworks and seminars.
|
||||||
* Your program **must free** all the resources before exiting.
|
- Your program **must free** all the resources before exiting.
|
||||||
|
|
||||||
[^1]: Subject to NDA.
|
[^1]: Subject to NDA.
|
|
@ -1,5 +1,5 @@
|
||||||
---
|
---
|
||||||
id: pb071-intro
|
id: cpp-intro
|
||||||
title: Introduction
|
title: Introduction
|
||||||
slug: /
|
slug: /
|
||||||
---
|
---
|
|
@ -106,7 +106,7 @@ contained.
|
||||||
|
|
||||||
Since frag creates a lot of support files (majority of them are dotfiles, i.e.
|
Since frag creates a lot of support files (majority of them are dotfiles, i.e.
|
||||||
hidden files), I recommend you to use following
|
hidden files), I recommend you to use following
|
||||||
[gitignore](pathname:///files/pb161/environment/gitignore) configuration that
|
[gitignore](pathname:///files/cpp/environment/gitignore) configuration that
|
||||||
should cover most of the scenarios.
|
should cover most of the scenarios.
|
||||||
|
|
||||||
### pre-commit ([link](https://pre-commit.com/))
|
### pre-commit ([link](https://pre-commit.com/))
|
|
@ -1,7 +1,7 @@
|
||||||
// @ts-check
|
// @ts-check
|
||||||
// Note: type annotations allow type checking and IDEs autocompletion
|
// Note: type annotations allow type checking and IDEs autocompletion
|
||||||
|
|
||||||
const {themes} = require("prism-react-renderer");
|
const { themes } = require("prism-react-renderer");
|
||||||
const lightCodeTheme = themes.vsLight;
|
const lightCodeTheme = themes.vsLight;
|
||||||
const darkCodeTheme = themes.dracula;
|
const darkCodeTheme = themes.dracula;
|
||||||
|
|
||||||
|
@ -10,9 +10,9 @@ const katex = require("rehype-katex");
|
||||||
|
|
||||||
require("dotenv").config();
|
require("dotenv").config();
|
||||||
|
|
||||||
class Subject {
|
class Docs {
|
||||||
constructor(subject, description) {
|
constructor(path, description) {
|
||||||
this.subject = subject;
|
this.path = path;
|
||||||
this.description = description;
|
this.description = description;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -20,9 +20,9 @@ class Subject {
|
||||||
return [
|
return [
|
||||||
"@docusaurus/plugin-content-docs",
|
"@docusaurus/plugin-content-docs",
|
||||||
{
|
{
|
||||||
id: this.subject,
|
id: this.path,
|
||||||
path: this.subject,
|
path: this.path,
|
||||||
routeBasePath: this.subject,
|
routeBasePath: this.path,
|
||||||
sidebarPath: require.resolve("./sidebars.js"),
|
sidebarPath: require.resolve("./sidebars.js"),
|
||||||
showLastUpdateTime: true,
|
showLastUpdateTime: true,
|
||||||
editUrl: "https://github.com/mfocko/blog/tree/main",
|
editUrl: "https://github.com/mfocko/blog/tree/main",
|
||||||
|
@ -35,27 +35,27 @@ class Subject {
|
||||||
navbar() {
|
navbar() {
|
||||||
return {
|
return {
|
||||||
type: "doc",
|
type: "doc",
|
||||||
docId: `${this.subject}-intro`,
|
docId: `${this.path}-intro`,
|
||||||
docsPluginId: this.subject,
|
docsPluginId: this.path,
|
||||||
label: `${this.subject.toUpperCase()}: ${this.description}`,
|
label: `${this.description}`,
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
footer() {
|
footer() {
|
||||||
return {
|
return {
|
||||||
label: `${this.subject.toUpperCase()}: ${this.description}`,
|
label: `${this.description}`,
|
||||||
to: this.subject,
|
to: this.path,
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const subjects = [
|
const subjects = [
|
||||||
new Subject("ib002", "Algorithms"),
|
new Docs("algorithms", "Algorithms"),
|
||||||
// new Subject("ib015", "Non-imperative programming"),
|
// new Docs("functional", "Non-imperative programming"),
|
||||||
// new Subject("ib110", "Introduction to informatics"),
|
// new Docs("automata", "Formal languages and automata"),
|
||||||
// new Subject("ib111", "Foundations of programming"),
|
// new Docs("foundations", "Foundations of programming"),
|
||||||
new Subject("pb071", "C"),
|
new Docs("c", "C"),
|
||||||
new Subject("pb161", "C++"),
|
new Docs("cpp", "C++"),
|
||||||
];
|
];
|
||||||
|
|
||||||
/** @type {import('@docusaurus/types').Config} */
|
/** @type {import('@docusaurus/types').Config} */
|
||||||
|
|
5
foundations/00-intro.md
Normal file
5
foundations/00-intro.md
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
---
|
||||||
|
id: foundations-intro
|
||||||
|
title: Introduction
|
||||||
|
slug: /
|
||||||
|
---
|
|
@ -1,5 +1,5 @@
|
||||||
---
|
---
|
||||||
id: ib110-intro
|
id: functional-intro
|
||||||
title: Introduction
|
title: Introduction
|
||||||
slug: /
|
slug: /
|
||||||
---
|
---
|
|
@ -1,5 +0,0 @@
|
||||||
---
|
|
||||||
id: pb161-intro
|
|
||||||
title: Introduction
|
|
||||||
slug: /
|
|
||||||
---
|
|
|
@ -14,4 +14,4 @@ graph {
|
||||||
d -- h
|
d -- h
|
||||||
|
|
||||||
h -- j
|
h -- j
|
||||||
}
|
}
|
|
@ -15,4 +15,4 @@ graph {
|
||||||
d -- h
|
d -- h
|
||||||
|
|
||||||
h -- j
|
h -- j
|
||||||
}
|
}
|
|
@ -10,4 +10,4 @@ digraph {
|
||||||
b -> h
|
b -> h
|
||||||
|
|
||||||
i -> d
|
i -> d
|
||||||
}
|
}
|
|
@ -9,4 +9,4 @@ digraph {
|
||||||
e -> j
|
e -> j
|
||||||
|
|
||||||
i -> d
|
i -> d
|
||||||
}
|
}
|
|
@ -44,4 +44,4 @@ digraph {
|
||||||
"Node(value=6, rank=0)" -> "nil9"
|
"Node(value=6, rank=0)" -> "nil9"
|
||||||
"Node(value=9, rank=0)" -> "nil10"
|
"Node(value=9, rank=0)" -> "nil10"
|
||||||
"Node(value=9, rank=0)" -> "nil11"
|
"Node(value=9, rank=0)" -> "nil11"
|
||||||
}
|
}
|
|
@ -44,4 +44,4 @@ digraph {
|
||||||
"Node(value=6, rank=0)" -> "nil9"
|
"Node(value=6, rank=0)" -> "nil9"
|
||||||
"Node(value=9, rank=0)" -> "nil10"
|
"Node(value=9, rank=0)" -> "nil10"
|
||||||
"Node(value=9, rank=0)" -> "nil11"
|
"Node(value=9, rank=0)" -> "nil11"
|
||||||
}
|
}
|
|
@ -31,4 +31,4 @@ digraph {
|
||||||
"Node(value=4, rank=0)" -> "nil7"
|
"Node(value=4, rank=0)" -> "nil7"
|
||||||
"Node(value=7, rank=0)" -> "nil8"
|
"Node(value=7, rank=0)" -> "nil8"
|
||||||
"Node(value=7, rank=0)" -> "nil9"
|
"Node(value=7, rank=0)" -> "nil9"
|
||||||
}
|
}
|
|
@ -6,7 +6,7 @@ digraph {
|
||||||
"Node(value=0, rank=0)" [label="0"]; #done
|
"Node(value=0, rank=0)" [label="0"]; #done
|
||||||
"Node(value=2, rank=0)" [label="2"]; #done
|
"Node(value=2, rank=0)" [label="2"]; #done
|
||||||
"Node(value=5, rank=1)" [label="5"]; #done
|
"Node(value=5, rank=1)" [label="5"]; #done
|
||||||
|
|
||||||
|
|
||||||
"nil2" [label="", color=none]
|
"nil2" [label="", color=none]
|
||||||
"nil3" [label="", color=none]
|
"nil3" [label="", color=none]
|
||||||
|
@ -34,7 +34,7 @@ digraph {
|
||||||
"Node(value=4, rank=0)" -> "nil7"
|
"Node(value=4, rank=0)" -> "nil7"
|
||||||
"Node(value=7, rank=0)" -> "nil8"
|
"Node(value=7, rank=0)" -> "nil8"
|
||||||
"Node(value=7, rank=0)" -> "8" [color="red"]
|
"Node(value=7, rank=0)" -> "8" [color="red"]
|
||||||
|
|
||||||
"8" -> "nil9"
|
"8" -> "nil9"
|
||||||
"8" -> "nil10"
|
"8" -> "nil10"
|
||||||
}
|
}
|
Some files were not shown because too many files have changed in this diff Show more
Loading…
Add table
Reference in a new issue