Skip to content

Commit 05bd77c

Browse files
authored
Add Kindergarten Garden exercise (#79)
1 parent c369c2e commit 05bd77c

14 files changed

+314
-0
lines changed

.gitignore

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1,4 +1,5 @@
11
*.swp
2+
.vscode
23
.DS_Store
34
bin/configlet
45
bin/configlet.exe

config.json

Lines changed: 8 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -218,6 +218,14 @@
218218
"prerequisites": [],
219219
"difficulty": 8
220220
},
221+
{
222+
"slug": "kindergarten-garden",
223+
"name": "Kindergarten Garden",
224+
"uuid": "fb354d1a-c85d-42d0-b919-f554eaa27a08",
225+
"practices": [],
226+
"prerequisites": [],
227+
"difficulty": 5
228+
},
221229
{
222230
"slug": "roman-numerals",
223231
"name": "Roman Numerals",
Lines changed: 9 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,9 @@
1+
# SQLite specific instructions
2+
3+
This exercise requires you set the `result` column of the `kindergarten-garden` table to the correct value based on the `diagram` and `student` columns.
4+
5+
## Table Schema
6+
7+
```sql
8+
CREATE TABLE "kindergarten-garden" ("diagram" TEXT, "student" TEXT, "result" TEXT);
9+
```
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: 22 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,22 @@
1+
{
2+
"authors": [
3+
"Steffan153"
4+
],
5+
"files": {
6+
"solution": [
7+
"kindergarten-garden.sql"
8+
],
9+
"test": [
10+
"kindergarten-garden_test.sql"
11+
],
12+
"example": [
13+
".meta/example.sql"
14+
],
15+
"editor": [
16+
"data.csv"
17+
]
18+
},
19+
"blurb": "Given a diagram, determine which plants each child in the kindergarten class is responsible for.",
20+
"source": "Exercise by the JumpstartLab team for students at The Turing School of Software and Design.",
21+
"source_url": "https://turing.edu"
22+
}
Lines changed: 14 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,14 @@
1+
UPDATE "kindergarten-garden"
2+
SET result = (
3+
WITH plants(p) AS (
4+
VALUES (1), (2), (1 + instr(diagram, char(10))), (2 + instr(diagram, char(10)))
5+
)
6+
SELECT group_concat(
7+
CASE SUBSTR(diagram, (unicode(student) - 65) * 2 + p, 1)
8+
WHEN 'G' THEN 'grass'
9+
WHEN 'V' THEN 'violets'
10+
WHEN 'C' THEN 'clover'
11+
WHEN 'R' THEN 'radishes'
12+
END
13+
) FROM plants
14+
);
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: 9 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,9 @@
1+
DROP TABLE IF EXISTS "kindergarten-garden";
2+
CREATE TABLE "kindergarten-garden" (
3+
"diagram" TEXT,
4+
"student" TEXT,
5+
"result" TEXT
6+
);
7+
8+
.mode csv
9+
.import ./data.csv kindergarten-garden
Lines changed: 34 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,34 @@
1+
"RC
2+
GG","Alice",""
3+
"VC
4+
RC","Alice",""
5+
"VVCG
6+
VVRC","Bob",""
7+
"VVCCGG
8+
VVCCGG","Bob",""
9+
"VVCCGG
10+
VVCCGG","Charlie",""
11+
"VRCGVVRVCGGCCGVRGCVCGCGV
12+
VRCCCGCRRGVCGCRVVCVGCGCV","Alice",""
13+
"VRCGVVRVCGGCCGVRGCVCGCGV
14+
VRCCCGCRRGVCGCRVVCVGCGCV","Bob",""
15+
"VRCGVVRVCGGCCGVRGCVCGCGV
16+
VRCCCGCRRGVCGCRVVCVGCGCV","Charlie",""
17+
"VRCGVVRVCGGCCGVRGCVCGCGV
18+
VRCCCGCRRGVCGCRVVCVGCGCV","David",""
19+
"VRCGVVRVCGGCCGVRGCVCGCGV
20+
VRCCCGCRRGVCGCRVVCVGCGCV","Eve",""
21+
"VRCGVVRVCGGCCGVRGCVCGCGV
22+
VRCCCGCRRGVCGCRVVCVGCGCV","Fred",""
23+
"VRCGVVRVCGGCCGVRGCVCGCGV
24+
VRCCCGCRRGVCGCRVVCVGCGCV","Ginny",""
25+
"VRCGVVRVCGGCCGVRGCVCGCGV
26+
VRCCCGCRRGVCGCRVVCVGCGCV","Harriet",""
27+
"VRCGVVRVCGGCCGVRGCVCGCGV
28+
VRCCCGCRRGVCGCRVVCVGCGCV","Ileana",""
29+
"VRCGVVRVCGGCCGVRGCVCGCGV
30+
VRCCCGCRRGVCGCRVVCVGCGCV","Joseph",""
31+
"VRCGVVRVCGGCCGVRGCVCGCGV
32+
VRCCCGCRRGVCGCRVVCVGCGCV","Kincaid",""
33+
"VRCGVVRVCGGCCGVRGCVCGCGV
34+
VRCCCGCRRGVCGCRVVCVGCGCV","Larry",""

0 commit comments

Comments
 (0)