diff options
| author | Abigail <abigail@abigail.freedom.nl> | 2022-01-15 22:28:24 +0100 |
|---|---|---|
| committer | Abigail <abigail@abigail.freedom.nl> | 2022-01-15 22:43:15 +0100 |
| commit | 229529902e59d78ca79aebf2e8a42ef1382cfa1d (patch) | |
| tree | 01fb59f399547581e05efec27755b22368174523 /challenge-147/abigail/pascal/ch-1.p | |
| parent | 3675e785bd1ddadcff97eb6725e1466eb1738f7a (diff) | |
| download | perlweeklychallenge-club-229529902e59d78ca79aebf2e8a42ef1382cfa1d.tar.gz perlweeklychallenge-club-229529902e59d78ca79aebf2e8a42ef1382cfa1d.tar.bz2 perlweeklychallenge-club-229529902e59d78ca79aebf2e8a42ef1382cfa1d.zip | |
Week 147: Pascal solutions
Diffstat (limited to 'challenge-147/abigail/pascal/ch-1.p')
| -rw-r--r-- | challenge-147/abigail/pascal/ch-1.p | 82 |
1 files changed, 82 insertions, 0 deletions
diff --git a/challenge-147/abigail/pascal/ch-1.p b/challenge-147/abigail/pascal/ch-1.p new file mode 100644 index 0000000000..24dc514652 --- /dev/null +++ b/challenge-147/abigail/pascal/ch-1.p @@ -0,0 +1,82 @@ +Program XXX; + +(* *) +(* See https://theweeklychallenge.org/blog/perl-weekly-challenge-147 *) +(* *) + +(* *) +(* Run as: fpc -och-1.out ch-1.p; ./ch-1.out *) +(* *) + +var + todo: array of integer; + new_todo: array of integer; + pow, i, d: integer; + count: integer = 20; + candidate: integer; + +function is_prime (p: integer): boolean; + var + i: integer; + + begin + if p = 2 then begin + is_prime := true; + exit; + end; + if p mod 2 = 0 then begin + is_prime := false; + exit; + end; + i := 3; + while i * i <= p do begin + if p mod i = 0 then begin + is_prime := false; + exit; + end; + i := i + 2; + end; + is_prime := true; + exit; + end; + + +begin + setlength (todo, 4); + todo [0] := 2; + todo [1] := 3; + todo [2] := 5; + todo [3] := 7; + for i := 0 to 3 do begin + write (todo [i], ' '); + end; + count := count - 4; + pow := 10; + while count > 0 do begin + setlength (new_todo, 0); + for d := 1 to 9 do begin + for i := 0 to length (todo) - 1 do begin + candidate := d * pow + todo [i]; + if is_prime (candidate) then begin + insert (candidate, new_todo, length (new_todo)); + write (candidate, ' '); + count := count - 1; + if count <= 0 then begin + break; + end; + end; + if count <= 0 then begin + break; + end; + end; + if count <= 0 then begin + break; + end; + end; + todo := new_todo; + pow := pow * 10; + end; + writeln (''); +end. + +end. |
