Skip to content

Commit eafd79a

Browse files
authored
add practice exercise kindergarten-garden (#769)
* add practice exercise kindergarten-garden * fixed nesting in runtests.jl * Update config.json Removed contributor, at their request
1 parent db189c1 commit eafd79a

File tree

8 files changed

+256
-0
lines changed

8 files changed

+256
-0
lines changed

config.json

Lines changed: 8 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1010,6 +1010,14 @@
10101010
"prerequisites": [],
10111011
"difficulty": 2
10121012
},
1013+
{
1014+
"slug": "kindergarten-garden",
1015+
"name": "Kindergarten Garden",
1016+
"uuid": "d196548e-ed57-43c3-b325-04c11d06397d",
1017+
"practices": [],
1018+
"prerequisites": [],
1019+
"difficulty": 3
1020+
},
10131021
{
10141022
"slug": "meetup",
10151023
"name": "Meetup",
Lines changed: 56 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,56 @@
1+
# Instructions
2+
3+
Your task is to, given a diagram, determine which plants each child in the kindergarten class is responsible for.
4+
5+
There are 12 children in the class:
6+
7+
- Alice, Bob, Charlie, David, Eve, Fred, Ginny, Harriet, Ileana, Joseph, Kincaid, and Larry.
8+
9+
Four different types of seeds are planted:
10+
11+
| Plant | Diagram encoding |
12+
| ------ | ---------------- |
13+
| Grass | G |
14+
| Clover | C |
15+
| Radish | R |
16+
| Violet | V |
17+
18+
Each child gets four cups, two on each row:
19+
20+
```text
21+
[window][window][window]
22+
........................ # each dot represents a cup
23+
........................
24+
```
25+
26+
Their teacher assigns cups to the children alphabetically by their names, which means that Alice comes first and Larry comes last.
27+
28+
Here is an example diagram representing Alice's plants:
29+
30+
```text
31+
[window][window][window]
32+
VR......................
33+
RG......................
34+
```
35+
36+
In the first row, nearest the windows, she has a violet and a radish.
37+
In the second row she has a radish and some grass.
38+
39+
Your program will be given the plants from left-to-right starting with the row nearest the windows.
40+
From this, it should be able to determine which plants belong to each student.
41+
42+
For example, if it's told that the garden looks like so:
43+
44+
```text
45+
[window][window][window]
46+
VRCGVVRVCGGCCGVRGCVCGCGV
47+
VRCCCGCRRGVCGCRVVCVGCGCV
48+
```
49+
50+
Then if asked for Alice's plants, it should provide:
51+
52+
- Violets, radishes, violets, radishes
53+
54+
While asking for Bob's plants would yield:
55+
56+
- Clover, grass, clover, clover
Lines changed: 6 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,6 @@
1+
# Introduction
2+
3+
The kindergarten class is learning about growing plants.
4+
The teacher thought it would be a good idea to give the class seeds to plant and grow in the dirt.
5+
To this end, the children have put little cups along the window sills and planted one type of plant in each cup.
6+
The children got to pick their favorites from four available types of seeds: grass, clover, radishes, and violets.
Lines changed: 19 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,19 @@
1+
{
2+
"authors": [
3+
"colinleach"
4+
],
5+
"files": {
6+
"solution": [
7+
"kindergarten-garden.jl"
8+
],
9+
"test": [
10+
"runtests.jl"
11+
],
12+
"example": [
13+
".meta/example.jl"
14+
]
15+
},
16+
"blurb": "Given a diagram, determine which plants each child in the kindergarten class is responsible for.",
17+
"source": "Exercise by the JumpstartLab team for students at The Turing School of Software and Design.",
18+
"source_url": "https://turing.edu"
19+
}
Lines changed: 13 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,13 @@
1+
const students = ["Alice", "Bob", "Charlie", "David", "Eve", "Fred", "Ginny",
2+
"Harriet", "Ileana", "Joseph", "Kincaid", "Larry"]
3+
4+
const species = Dict('G' => "grass", 'C' => "clover", 'R' => "radishes", 'V' => "violets")
5+
6+
function plants(diagram, student)
7+
rows = split(diagram, '\n')
8+
start = 2 * index(students, student) - 1
9+
owns = rows[1][start:(start + 1)] * rows[2][start:(start + 1)]
10+
[species[p] for p in owns]
11+
end
12+
13+
index(A, val) = findfirst(x -> x == val, A)
Lines changed: 61 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,61 @@
1+
# This is an auto-generated file.
2+
#
3+
# Regenerating this file via `configlet sync` will:
4+
# - Recreate every `description` key/value pair
5+
# - Recreate every `reimplements` key/value pair, where they exist in problem-specifications
6+
# - Remove any `include = true` key/value pair (an omitted `include` key implies inclusion)
7+
# - Preserve any other key/value pair
8+
#
9+
# As user-added comments (using the # character) will be removed when this file
10+
# is regenerated, comments can be added via a `comment` key.
11+
12+
[1fc316ed-17ab-4fba-88ef-3ae78296b692]
13+
description = "partial garden -> garden with single student"
14+
15+
[acd19dc1-2200-4317-bc2a-08f021276b40]
16+
description = "partial garden -> different garden with single student"
17+
18+
[c376fcc8-349c-446c-94b0-903947315757]
19+
description = "partial garden -> garden with two students"
20+
21+
[2d620f45-9617-4924-9d27-751c80d17db9]
22+
description = "partial garden -> multiple students for the same garden with three students -> second student's garden"
23+
24+
[57712331-4896-4364-89f8-576421d69c44]
25+
description = "partial garden -> multiple students for the same garden with three students -> third student's garden"
26+
27+
[149b4290-58e1-40f2-8ae4-8b87c46e765b]
28+
description = "full garden -> for Alice, first student's garden"
29+
30+
[ba25dbbc-10bd-4a37-b18e-f89ecd098a5e]
31+
description = "full garden -> for Bob, second student's garden"
32+
33+
[566b621b-f18e-4c5f-873e-be30544b838c]
34+
description = "full garden -> for Charlie"
35+
36+
[3ad3df57-dd98-46fc-9269-1877abf612aa]
37+
description = "full garden -> for David"
38+
39+
[0f0a55d1-9710-46ed-a0eb-399ba8c72db2]
40+
description = "full garden -> for Eve"
41+
42+
[a7e80c90-b140-4ea1-aee3-f4625365c9a4]
43+
description = "full garden -> for Fred"
44+
45+
[9d94b273-2933-471b-86e8-dba68694c615]
46+
description = "full garden -> for Ginny"
47+
48+
[f55bc6c2-ade8-4844-87c4-87196f1b7258]
49+
description = "full garden -> for Harriet"
50+
51+
[759070a3-1bb1-4dd4-be2c-7cce1d7679ae]
52+
description = "full garden -> for Ileana"
53+
54+
[78578123-2755-4d4a-9c7d-e985b8dda1c6]
55+
description = "full garden -> for Joseph"
56+
57+
[6bb66df7-f433-41ab-aec2-3ead6e99f65b]
58+
description = "full garden -> for Kincaid, second to last student's garden"
59+
60+
[d7edec11-6488-418a-94e6-ed509e0fa7eb]
61+
description = "full garden -> for Larry, last student's garden"
Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,3 @@
1+
function plants(diagram, student)
2+
3+
end
Lines changed: 90 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,90 @@
1+
using Test
2+
3+
include("kindergarten-garden.jl")
4+
5+
@testset verbose = true "tests" begin
6+
@testset "partial garden" begin
7+
@testset "garden with single student" begin
8+
@test plants("RC\nGG", "Alice") == ["radishes", "clover", "grass", "grass"]
9+
end
10+
11+
@testset "different garden with single student" begin
12+
@test plants("VC\nRC", "Alice") == ["violets", "clover", "radishes", "clover"]
13+
end
14+
15+
@testset "garden with two students" begin
16+
@test plants("VVCG\nVVRC", "Bob") == ["clover", "grass", "radishes", "clover"]
17+
end
18+
19+
@testset "second student's garden" begin
20+
@test plants("VVCCGG\nVVCCGG", "Bob") == ["clover", "clover", "clover", "clover"]
21+
end
22+
23+
@testset "third student's garden" begin
24+
@test plants("VVCCGG\nVVCCGG", "Charlie") == ["grass", "grass", "grass", "grass"]
25+
end
26+
end
27+
28+
@testset "full garden" begin
29+
@testset "for Alice, first student's garden" begin
30+
diagram = "VRCGVVRVCGGCCGVRGCVCGCGV\nVRCCCGCRRGVCGCRVVCVGCGCV"
31+
@test plants(diagram, "Alice") == ["violets", "radishes", "violets", "radishes"]
32+
end
33+
34+
@testset "for Bob, second student's garden" begin
35+
diagram = "VRCGVVRVCGGCCGVRGCVCGCGV\nVRCCCGCRRGVCGCRVVCVGCGCV"
36+
@test plants(diagram, "Bob") == ["clover", "grass", "clover", "clover"]
37+
end
38+
39+
@testset "for Charlie" begin
40+
diagram = "VRCGVVRVCGGCCGVRGCVCGCGV\nVRCCCGCRRGVCGCRVVCVGCGCV"
41+
@test plants(diagram, "Charlie") == ["violets", "violets", "clover", "grass"]
42+
end
43+
44+
@testset "for David" begin
45+
diagram = "VRCGVVRVCGGCCGVRGCVCGCGV\nVRCCCGCRRGVCGCRVVCVGCGCV"
46+
@test plants(diagram, "David") == ["radishes", "violets", "clover", "radishes"]
47+
end
48+
49+
@testset "for Eve" begin
50+
diagram = "VRCGVVRVCGGCCGVRGCVCGCGV\nVRCCCGCRRGVCGCRVVCVGCGCV"
51+
@test plants(diagram, "Eve") == ["clover", "grass", "radishes", "grass"]
52+
end
53+
54+
@testset "for Fred" begin
55+
diagram = "VRCGVVRVCGGCCGVRGCVCGCGV\nVRCCCGCRRGVCGCRVVCVGCGCV"
56+
@test plants(diagram, "Fred") == ["grass", "clover", "violets", "clover"]
57+
end
58+
59+
@testset "for Ginny" begin
60+
diagram = "VRCGVVRVCGGCCGVRGCVCGCGV\nVRCCCGCRRGVCGCRVVCVGCGCV"
61+
@test plants(diagram, "Ginny") == ["clover", "grass", "grass", "clover"]
62+
end
63+
64+
@testset "for Harriet" begin
65+
diagram = "VRCGVVRVCGGCCGVRGCVCGCGV\nVRCCCGCRRGVCGCRVVCVGCGCV"
66+
@test plants(diagram, "Harriet") == ["violets", "radishes", "radishes", "violets"]
67+
end
68+
69+
@testset "for Ileana" begin
70+
diagram = "VRCGVVRVCGGCCGVRGCVCGCGV\nVRCCCGCRRGVCGCRVVCVGCGCV"
71+
@test plants(diagram, "Ileana") == ["grass", "clover", "violets", "clover"]
72+
end
73+
74+
@testset "for Joseph" begin
75+
diagram = "VRCGVVRVCGGCCGVRGCVCGCGV\nVRCCCGCRRGVCGCRVVCVGCGCV"
76+
@test plants(diagram, "Joseph") == ["violets", "clover", "violets", "grass"]
77+
end
78+
79+
@testset "for Kincaid, second to last student's garden" begin
80+
diagram = "VRCGVVRVCGGCCGVRGCVCGCGV\nVRCCCGCRRGVCGCRVVCVGCGCV"
81+
@test plants(diagram, "Kincaid") == ["grass", "clover", "clover", "grass"]
82+
end
83+
84+
@testset "for Larry, last student's garden" begin
85+
diagram = "VRCGVVRVCGGCCGVRGCVCGCGV\nVRCCCGCRRGVCGCRVVCVGCGCV"
86+
@test plants(diagram, "Larry") == ["grass", "violets", "clover", "violets"]
87+
end
88+
89+
end
90+
end

0 commit comments

Comments
 (0)