Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[v3] Add prerequisites to Practice Exercises #583

Merged
merged 132 commits into from
Mar 1, 2021
Merged
Changes from 17 commits
Commits
Show all changes
132 commits
Select commit Hold shift + click to select a range
9061410
rna-transcription
angelikatyborska Jan 31, 2021
706095b
Word count
angelikatyborska Jan 31, 2021
b34a3d3
Roman numerals
angelikatyborska Jan 31, 2021
a13f68f
Bob
angelikatyborska Jan 31, 2021
400e2e9
Beer song
angelikatyborska Jan 31, 2021
ebff913
Robot simulator
angelikatyborska Jan 31, 2021
406c7be
List ops
angelikatyborska Jan 31, 2021
5fbe0c5
Markdown
angelikatyborska Jan 31, 2021
e150a6b
Bank account
angelikatyborska Jan 31, 2021
13078bc
Zipper
angelikatyborska Jan 31, 2021
c3d40c3
Bowling
angelikatyborska Jan 31, 2021
9321427
Forth
angelikatyborska Jan 31, 2021
bde18bf
Resistor color
angelikatyborska Jan 31, 2021
ce15309
Two fer
angelikatyborska Jan 31, 2021
99171f2
Nucleotide count
angelikatyborska Jan 31, 2021
20457d6
Pig latin
angelikatyborska Jan 31, 2021
f94c12d
Protein translation
angelikatyborska Jan 31, 2021
280531a
Rotational cipher
angelikatyborska Jan 31, 2021
d656b65
Secret handshake
angelikatyborska Jan 31, 2021
081fa9e
Space age
angelikatyborska Jan 31, 2021
a83f3fb
Strain
angelikatyborska Jan 31, 2021
9812964
Accumulate
angelikatyborska Jan 31, 2021
2ea69b9
Acronym
angelikatyborska Jan 31, 2021
86ae353
Raindrops
angelikatyborska Jan 31, 2021
578edb0
Run length encoding
angelikatyborska Jan 31, 2021
4b0947f
Series
angelikatyborska Jan 31, 2021
59b47dd
Dnd character
angelikatyborska Jan 31, 2021
7e142ba
Pangram
angelikatyborska Jan 31, 2021
beb4910
Scrabble score
angelikatyborska Jan 31, 2021
fa937a8
Sum of multiples
angelikatyborska Jan 31, 2021
2d4b9a6
Grade school
angelikatyborska Jan 31, 2021
1351191
Isogram
angelikatyborska Jan 31, 2021
0dc6ff9
Twelve days
angelikatyborska Jan 31, 2021
1a65ea0
Collatz conjecture
angelikatyborska Jan 31, 2021
cc15651
Sublist
angelikatyborska Jan 31, 2021
8ff82e0
Triangle
angelikatyborska Jan 31, 2021
7270573
Flatten array
angelikatyborska Jan 31, 2021
adde21a
Matching brackets
angelikatyborska Jan 31, 2021
793b51c
Anagram
angelikatyborska Jan 31, 2021
9cc9e1b
Hamming
angelikatyborska Jan 31, 2021
24f4386
Matrix
angelikatyborska Jan 31, 2021
c27d129
Phone number
angelikatyborska Jan 31, 2021
b807e89
Say
angelikatyborska Jan 31, 2021
6f57711
Nth prime
angelikatyborska Jan 31, 2021
051e3a8
Binary search
angelikatyborska Jan 31, 2021
dd709b7
ISBN verifier
angelikatyborska Jan 31, 2021
44a3b21
Leap
angelikatyborska Jan 31, 2021
9285aa1
Tournament
angelikatyborska Jan 31, 2021
5ab89d8
All your base
angelikatyborska Jan 31, 2021
2fd96b0
Binary search tree
angelikatyborska Jan 31, 2021
8e2deab
Grains
angelikatyborska Jan 31, 2021
8be1208
Meetup
angelikatyborska Jan 31, 2021
acf13cd
Simple linked list
angelikatyborska Jan 31, 2021
449cfd4
ETL
angelikatyborska Jan 31, 2021
3bf5109
Binary
angelikatyborska Jan 31, 2021
265e55d
Change
angelikatyborska Jan 31, 2021
7173260
Transpose
angelikatyborska Jan 31, 2021
2bd7592
OCR numbers
angelikatyborska Jan 31, 2021
531cd51
Kindergarten garden
angelikatyborska Jan 31, 2021
d3154c9
Diamond
angelikatyborska Jan 31, 2021
45fb4fa
Luhn
angelikatyborska Jan 31, 2021
af2555a
Scale generator
angelikatyborska Jan 31, 2021
a6f67fe
Rail fence cipher
angelikatyborska Jan 31, 2021
f634f3f
Hello world should have no prerequisites
angelikatyborska Jan 31, 2021
1c4926b
Gigasecond
angelikatyborska Jan 31, 2021
e5fadf2
Hexadecimal
angelikatyborska Jan 31, 2021
2a6c5f5
Perfect numbers
angelikatyborska Jan 31, 2021
7432e82
Prime factors
angelikatyborska Jan 31, 2021
c78f6a9
Diffie hellman
angelikatyborska Jan 31, 2021
d050b6f
Parallel letter frequency
angelikatyborska Jan 31, 2021
efdf8a5
Palindrome products
angelikatyborska Jan 31, 2021
1151ba8
Pascals triangle
angelikatyborska Jan 31, 2021
9d33b39
Spiral matrix
angelikatyborska Jan 31, 2021
1de0f6d
Merge branch 'main' into add-prerequisites-to-practice-exercises
angelikatyborska Feb 2, 2021
713f51f
Do not require "errors" on easy exerises
angelikatyborska Feb 2, 2021
45f15bb
Remove concepts that don't exist yet
angelikatyborska Feb 3, 2021
7ceca7d
Custom set
angelikatyborska Feb 3, 2021
70d08d1
Saddle points
angelikatyborska Feb 3, 2021
41fd756
Connect
angelikatyborska Feb 3, 2021
3ebe7f3
Minesweeper
angelikatyborska Feb 3, 2021
f9e3129
Queen attack
angelikatyborska Feb 3, 2021
0605d3b
Armstrong Numbers
angelikatyborska Feb 3, 2021
95524f4
Simple Cipher
angelikatyborska Feb 3, 2021
c5186d2
Allergies
angelikatyborska Feb 3, 2021
35a70a3
Crypto Square
angelikatyborska Feb 3, 2021
7bddc47
Largest Series Product
angelikatyborska Feb 3, 2021
97411c1
Clock
angelikatyborska Feb 3, 2021
2aab62a
Sieve
angelikatyborska Feb 3, 2021
52e41ef
Poker
angelikatyborska Feb 3, 2021
42cad00
Atbash Cipher
angelikatyborska Feb 3, 2021
9e97901
Grep
angelikatyborska Feb 3, 2021
f7d4c1d
Difference Of Squares
angelikatyborska Feb 3, 2021
883a235
Dominoes
angelikatyborska Feb 3, 2021
87d3b5d
Alphametics
angelikatyborska Feb 3, 2021
f282b83
Pythagorean Triplet
angelikatyborska Feb 3, 2021
33696af
Wordy
angelikatyborska Feb 3, 2021
06ffd87
Dot DSL
angelikatyborska Feb 3, 2021
fe928c6
"practices" batch 1
angelikatyborska Feb 4, 2021
0c3092c
Fix json syntax error
angelikatyborska Feb 4, 2021
d148f38
"practices" batch 2
angelikatyborska Feb 4, 2021
b3a6ea8
"practices" batch 3
angelikatyborska Feb 4, 2021
41cd680
"practices" batch 4
angelikatyborska Feb 4, 2021
560965a
"practices" batch 5
angelikatyborska Feb 5, 2021
0cedbd3
Find a "keyword-lists" exercise
angelikatyborska Feb 5, 2021
23a73f0
Valid syntax in bin_tree.ex comment
angelikatyborska Feb 5, 2021
0f0872d
Add 1 "practices" for booleans, if, and case
angelikatyborska Feb 5, 2021
49662b0
fix syntax error
angelikatyborska Feb 5, 2021
6afab11
Add a throw-away analysis script
angelikatyborska Feb 5, 2021
4402161
Typos
angelikatyborska Feb 5, 2021
110d12c
Merge branch 'main' into add-prerequisites-to-practice-exercises
angelikatyborska Feb 14, 2021
30f0b77
resistor-color doesn't need recursion
angelikatyborska Feb 14, 2021
9da9473
nucleotide-count doesn't need recursion
angelikatyborska Feb 14, 2021
d8e83a5
space-age practices module-attributes-as-constants
angelikatyborska Feb 14, 2021
d1aca4b
sum-of-multiples doesn't need recursion
angelikatyborska Feb 14, 2021
03af2b6
all-your-base doesn't need nil anymore
angelikatyborska Feb 14, 2021
e27914a
Find more cases of default-arguments
angelikatyborska Feb 14, 2021
7ca92ff
Redefine errors
angelikatyborska Feb 14, 2021
53565f8
Find more cases of nil
angelikatyborska Feb 14, 2021
7883237
Find more cases of pipe-operator
angelikatyborska Feb 14, 2021
501d5e7
prettier'd
neenjaw Feb 14, 2021
6bd38a0
additions
neenjaw Feb 14, 2021
214e36e
genserver removed from bank account
neenjaw Feb 14, 2021
4f91cee
clean up prettier ignore
neenjaw Feb 14, 2021
8fd781b
prettierrc cleanup
neenjaw Feb 14, 2021
018235b
Update config.json
angelikatyborska Feb 15, 2021
483c76e
Fix "string" => "strings"
angelikatyborska Feb 15, 2021
cacf196
Modify script to detect typos
angelikatyborska Feb 15, 2021
7b8df24
Merge branch 'main' into add-prerequisites-to-practice-exercises
angelikatyborska Feb 20, 2021
7036e74
Merge branch 'main' into add-prerequisites-to-practice-exercises
angelikatyborska Feb 26, 2021
6479543
Merge branch 'main' into add-prerequisites-to-practice-exercises
angelikatyborska Mar 1, 2021
158531d
Remove topics
angelikatyborska Mar 1, 2021
090eb72
Fix syntax errors
angelikatyborska Mar 1, 2021
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
163 changes: 145 additions & 18 deletions config.json
Original file line number Diff line number Diff line change
Expand Up @@ -489,7 +489,7 @@
"slug": "hello-world",
"name": "Hello World",
"uuid": "cc96d65d-1c79-40d0-8fd2-9a6665a43b01",
"prerequisites": [],
"prerequisites": ["basics"],
"difficulty": 1,
"topics": [
"strings"
Expand All @@ -499,7 +499,13 @@
"slug": "rna-transcription",
"name": "RNA Transcription",
"uuid": "a4629a60-752f-4234-99f1-6b3ac0b4ba18",
"prerequisites": [],
"prerequisites": [
"charlists",
"pattern-matching",
"multiple-clause-functions",
"case",
"enum"
],
"difficulty": 2,
"topics": [
"strings"
Expand All @@ -509,7 +515,12 @@
"slug": "word-count",
"name": "Word Count",
"uuid": "4a24ba2f-ae92-4095-be53-64bc881422ea",
"prerequisites": [],
"prerequisites": [
"strings",
"regular-expressions",
"enum",
"maps"
],
"difficulty": 2,
"topics": [
"lists",
Expand All @@ -521,7 +532,17 @@
"slug": "roman-numerals",
"name": "Roman Numerals",
"uuid": "4c0ece49-5710-43a1-88b3-2fb149de8552",
"prerequisites": [],
"prerequisites": [
"strings",
"recursion",
"guards",
"default-arguments",
"multiple-clause-functions",
"enum",
"maps",
"cond",
"case"
],
"difficulty": 2,
"topics": [
"algorithms",
Expand All @@ -532,7 +553,11 @@
"slug": "bob",
"name": "Bob",
"uuid": "d20b49dc-cb6d-45fc-a168-78d002072c75",
"prerequisites": [],
"prerequisites": [
"strings",
"regular-expressions",
"cond"
],
"difficulty": 2,
"topics": [
"control_flow",
Expand All @@ -543,7 +568,13 @@
"slug": "beer-song",
"name": "Beer Song",
"uuid": "24db624b-7c80-409d-97d5-e1177f025c67",
"prerequisites": [],
"prerequisites": [
"strings",
"multiple-clause-functions",
"ranges",
"enum",
"recursion"
],
"difficulty": 3,
"topics": [
"pattern_matching",
Expand All @@ -554,7 +585,16 @@
"slug": "robot-simulator",
"name": "Robot Simulator",
"uuid": "e5e55560-852f-4551-b4da-c9f4a3141470",
"prerequisites": [],
"prerequisites": [
"multiple-clause-functions",
"guards",
"pattern-matching",
"case",
"strings",
"enum",
"structs",
"errors"
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I am adding "errors" as a prerequisite to each exercise that uses the {:ok, any} | {:error, any} | :error pattern. I'm not entirely sure if that's a good idea because the "errors" concept is very far down the concept tree. Maybe it would be better to assume that tuples and atoms are enough? What do you think?

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I could go either way on this. If there aren't enough exercises earlier on, we could leave that out an let tuples be enough. If there are, we could leave it and wait to name the pattern before the exercise appears.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We have very few exercises early on. I think I'm going to use this concept as a way of steering people into easier exercises. So for easy ones, like triangle, I'm going to remove errors as a prerequisite so that people can do it early. They are unlikely to overcomplicate those by trying to raise and rescue :). But for complicated ones, like forth or robot-simulator, I'll keep errors as a prerequisite, "for the student's own good".

],
"difficulty": 6,
"topics": [
"pattern_matching",
Expand All @@ -565,7 +605,13 @@
"slug": "list-ops",
"name": "List Ops",
"uuid": "86658a31-d401-401b-80df-2c4df35f9b15",
"prerequisites": [],
"prerequisites": [
"lists",
"recursion",
"tail-call-recursion",
"multiple-clause-functions",
"pattern-matching"
],
"difficulty": 4,
"topics": [
"enumeration",
Expand All @@ -577,7 +623,16 @@
"slug": "markdown",
"name": "Markdown",
"uuid": "5dfa24bf-e77c-47c6-88e1-e50cbeecd159",
"prerequisites": [],
"prerequisites": [
"strings",
"enum",
"recursion",
"regular-expressions",
"multiple-clause-functions",
"pattern-matching",
"cond",
"if"
],
"difficulty": 5,
"topics": [
"refactoring"
Expand All @@ -587,7 +642,11 @@
"slug": "bank-account",
"name": "Bank Account",
"uuid": "5d5e0f6c-f4b7-418e-88f8-4b1d0f99bfb0",
"prerequisites": [],
"prerequisites": [
"processes",
"agent",
"genserver"
],
"difficulty": 7,
"topics": [
"otp"
Expand All @@ -597,7 +656,16 @@
"slug": "zipper",
"name": "Zipper",
"uuid": "bc315734-051c-4735-9a8a-3aacb094d2ca",
"prerequisites": [],
"prerequisites": [
"recursion",
"structs",
"protocols",
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I don't think protocols are necessary to solve this exercise, but the boilerplate code includes a protocol implementation (https://github.com/exercism/elixir/blob/main/exercises/practice/zipper/lib/bin_tree.ex#L15-L33) so I added it here to avoid students being confused by the boilerplate.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think Zipper used to appear after Clock, so they were introduced to protocols by that point. I don't think students that I have encountered have been confused by this at this point with Clock having been removed from the core pathway.

"if",
"nil",
"case",
"pattern-matching",
"multiple-clause-functions"
],
"difficulty": 8,
"topics": [
"algorithms",
Expand All @@ -610,7 +678,19 @@
"slug": "bowling",
"name": "Bowling",
"uuid": "3b252cc6-cc55-4187-891e-c10aaabac81f",
"prerequisites": [],
"prerequisites": [
"pattern-matching",
"multiple-clause-functions",
"guards",
"lists",
"enum",
"recursion",
"cond",
"if",
"case",
"structs",
"errors"
],
"difficulty": 8,
"topics": [
"algorithms",
Expand All @@ -622,7 +702,23 @@
"slug": "forth",
"name": "Forth",
"uuid": "2abfa3e5-d358-4a07-91f9-d4ad04eb719d",
"prerequisites": [],
"prerequisites": [
"pattern-matching",
"multiple-clause-functions",
"guards",
"strings",
"regular-expressions",
"maps",
"lists",
"enum",
"recursion",
"cond",
"if",
"case",
"structs",
"errors",
"exceptions"
],
"difficulty": 10,
"topics": [
"parsers"
Expand All @@ -632,7 +728,11 @@
"slug": "resistor-color",
"name": "Resistor Color",
"uuid": "12efd520-e3e5-437f-b93e-38af14aa605d",
"prerequisites": [],
"prerequisites": [
"lists",
"enum",
"recursion"
],
"difficulty": 1,
"topics": [
"enumerables"
Expand All @@ -642,7 +742,11 @@
"slug": "two-fer",
"name": "Two Fer",
"uuid": "e7f3280e-0bef-4fac-8a69-cbfa2e5f818a",
"prerequisites": [],
"prerequisites": [
"strings",
"guards",
"default-arguments"
],
"difficulty": 1,
"topics": [
"strings"
Expand All @@ -652,7 +756,12 @@
"slug": "nucleotide-count",
"name": "Nucleotide Count",
"uuid": "7404e885-747a-46fc-be0c-c53f4b0e162f",
"prerequisites": [],
"prerequisites": [
"charlists",
"maps",
"enum",
"recursion"
],
"difficulty": 2,
"topics": [
"enumerables",
Expand All @@ -664,7 +773,15 @@
"slug": "pig-latin",
"name": "Pig Latin",
"uuid": "3aa45a2b-d3bc-4763-b11d-5d41a1cf505c",
"prerequisites": [],
"prerequisites": [
"strings",
"regular-expressions",
"enum",
"recursion",
"cond",
"if",
"case"
],
"difficulty": 2,
"topics": [
"pattern_matching",
Expand All @@ -675,7 +792,17 @@
"slug": "protein-translation",
"name": "Protein Translation",
"uuid": "84af7be8-8f90-4990-9d48-b5324a0d4354",
"prerequisites": [],
"prerequisites": [
"maps",
"enum",
"recursion",
"case",
"pattern-matching",
"strings",
"binaries",
Copy link
Member Author

@angelikatyborska angelikatyborska Jan 31, 2021

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

A lot of solutions chose binary pattern-matching for splitting the string into three-letter substrings.

"regular-expressions",
"errors"
],
Copy link
Member Author

@angelikatyborska angelikatyborska Jan 31, 2021

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The example solution for this exercise uses metaprogramming like this:
https://github.com/exercism/elixir/blob/main/exercises/practice/protein-translation/.meta/example.ex#L49-L52

I wonder if this should become a concepts of its own? How would it be called, which parts of metaprogramming would it cover?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Maybe it could cover quote and unquote so that those are not new concepts when macros are introduced?

"difficulty": 2,
"topics": [
"pattern_matching",
Expand Down