diff options
| author | Tyge Løvset <[email protected]> | 2023-03-01 14:54:36 +0100 |
|---|---|---|
| committer | Tyge Løvset <[email protected]> | 2023-03-01 14:54:36 +0100 |
| commit | a203314647b5c37c7e40230551457f006ff36cd5 (patch) | |
| tree | 3d8b9b29595577bee0926434820d602a29487ea3 /misc/examples/triples.c | |
| parent | 78a7e85535fd02e643bf98103223d4218e80133f (diff) | |
| download | STC-modified-a203314647b5c37c7e40230551457f006ff36cd5.tar.gz STC-modified-a203314647b5c37c7e40230551457f006ff36cd5.zip | |
Reverted example moves.
Diffstat (limited to 'misc/examples/triples.c')
| -rw-r--r-- | misc/examples/triples.c | 52 |
1 files changed, 52 insertions, 0 deletions
diff --git a/misc/examples/triples.c b/misc/examples/triples.c new file mode 100644 index 00000000..8a46d653 --- /dev/null +++ b/misc/examples/triples.c @@ -0,0 +1,52 @@ +// https://quuxplusone.github.io/blog/2019/03/06/pythagorean-triples/ + +#include <stc/algo/coroutine.h> +#include <stdio.h> + +void triples_vanilla(int n) { + for (int i = 1, z = 1;; ++z) { + for (int x = 1; x < z; ++x) { + for (int y = x; y < z; ++y) { + if (x*x + y*y == z*z) { + printf("{%d, %d, %d},\n", x, y, z); + if (++i > n) goto done; + } + } + } + } + done:; +} + +struct triples { + int n; + int x, y, z; + int cco_state; +}; + +bool triples_coro(struct triples* t) { + cco_begin(t); + for (t->z = 1;; ++t->z) { + for (t->x = 1; t->x < t->z; ++t->x) { + for (t->y = t->x; t->y < t->z; ++t->y) { + if (t->x*t->x + t->y*t->y == t->z*t->z) { + if (t->n-- == 0) cco_return; + cco_yield(true); + } + } + } + } + cco_final: + cco_end(false); +} + + +int main() +{ + puts("Vanilla triples:"); + triples_vanilla(6); + + puts("\nCoroutine triples:"); + struct triples t = {6}; + while (triples_coro(&t)) + printf("{%d, %d, %d},\n", t.x, t.y, t.z); +} |
