Skip to content

Commit f883e0b

Browse files
Add proverb exercise (#70)
1 parent bcd08b3 commit f883e0b

File tree

7 files changed

+121
-0
lines changed

7 files changed

+121
-0
lines changed

config.json

Lines changed: 8 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -385,6 +385,14 @@
385385
"prerequisites": [],
386386
"difficulty": 5
387387
},
388+
{
389+
"slug": "proverb",
390+
"name": "Proverb",
391+
"uuid": "901faf71-670a-4a8a-b948-e7df0b8ed248",
392+
"practices": [],
393+
"prerequisites": [],
394+
"difficulty": 5
395+
},
388396
{
389397
"slug": "run-length-encoding",
390398
"name": "Run-Length Encoding",
Lines changed: 19 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,19 @@
1+
# Instructions
2+
3+
For want of a horseshoe nail, a kingdom was lost, or so the saying goes.
4+
5+
Given a list of inputs, generate the relevant proverb.
6+
For example, given the list `["nail", "shoe", "horse", "rider", "message", "battle", "kingdom"]`, you will output the full text of this proverbial rhyme:
7+
8+
```text
9+
For want of a nail the shoe was lost.
10+
For want of a shoe the horse was lost.
11+
For want of a horse the rider was lost.
12+
For want of a rider the message was lost.
13+
For want of a message the battle was lost.
14+
For want of a battle the kingdom was lost.
15+
And all for the want of a nail.
16+
```
17+
18+
Note that the list of inputs may vary; your solution should be able to handle lists of arbitrary length and content.
19+
No line of the output text should be a static, unchanging string; all should vary according to the input given.
Lines changed: 19 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,19 @@
1+
{
2+
"authors": [
3+
"keiravillekode"
4+
],
5+
"files": {
6+
"solution": [
7+
"proverb.fut"
8+
],
9+
"test": [
10+
"test.fut"
11+
],
12+
"example": [
13+
".meta/example.fut"
14+
]
15+
},
16+
"blurb": "For want of a horseshoe nail, a kingdom was lost, or so the saying goes. Output the full text of this proverbial rhyme.",
17+
"source": "Wikipedia",
18+
"source_url": "https://en.wikipedia.org/wiki/For_Want_of_a_Nail"
19+
}
Lines changed: 12 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,12 @@
1+
def recite (strings: []u8): []u8 =
2+
if length strings == 0 then [] else
3+
let offsets = loop offsets = [0] for i < length strings do
4+
if strings[i] != '\n' then offsets else
5+
offsets ++ [i + 1]
6+
in
7+
let n = length offsets - 2
8+
in
9+
let result = loop result = "" for i < n do
10+
result ++ "For want of a " ++ strings[offsets[i]:offsets[i + 1] - 1] ++ " the " ++ strings[offsets[i + 1]:offsets[i + 2] - 1] ++ " was lost.\n"
11+
in
12+
result ++ "And all for the want of a " ++ strings[offsets[0]:offsets[1] - 1] ++ ".\n"
Lines changed: 28 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,28 @@
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+
[e974b73e-7851-484f-8d6d-92e07fe742fc]
13+
description = "zero pieces"
14+
15+
[2fcd5f5e-8b82-4e74-b51d-df28a5e0faa4]
16+
description = "one piece"
17+
18+
[d9d0a8a1-d933-46e2-aa94-eecf679f4b0e]
19+
description = "two pieces"
20+
21+
[c95ef757-5e94-4f0d-a6cb-d2083f5e5a83]
22+
description = "three pieces"
23+
24+
[433fb91c-35a2-4d41-aeab-4de1e82b2126]
25+
description = "full proverb"
26+
27+
[c1eefa5a-e8d9-41c7-91d4-99fab6d6b9f7]
28+
description = "four pieces modernized"
Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+
def recite (strings: []u8): []u8 = ???

exercises/practice/proverb/test.fut

Lines changed: 34 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,34 @@
1+
import "proverb"
2+
3+
-- zero pieces
4+
-- ==
5+
-- input { "" }
6+
-- output { "" }
7+
8+
-- one piece
9+
-- ==
10+
-- input { "nail\n" }
11+
-- output { "And all for the want of a nail.\n" }
12+
13+
-- two pieces
14+
-- ==
15+
-- input { "nail\nshoe\n" }
16+
-- output { "For want of a nail the shoe was lost.\nAnd all for the want of a nail.\n" }
17+
18+
-- three pieces
19+
-- ==
20+
-- input { "nail\nshoe\nhorse\n" }
21+
-- output { "For want of a nail the shoe was lost.\nFor want of a shoe the horse was lost.\nAnd all for the want of a nail.\n" }
22+
23+
-- full proverb
24+
-- ==
25+
-- input { "nail\nshoe\nhorse\nrider\nmessage\nbattle\nkingdom\n" }
26+
-- output { "For want of a nail the shoe was lost.\nFor want of a shoe the horse was lost.\nFor want of a horse the rider was lost.\nFor want of a rider the message was lost.\nFor want of a message the battle was lost.\nFor want of a battle the kingdom was lost.\nAnd all for the want of a nail.\n" }
27+
28+
-- four pieces modernized
29+
-- ==
30+
-- input { "pin\ngun\nsoldier\nbattle\n" }
31+
-- output { "For want of a pin the gun was lost.\nFor want of a gun the soldier was lost.\nFor want of a soldier the battle was lost.\nAnd all for the want of a pin.\n" }
32+
33+
let main (strings: []u8): []u8 =
34+
recite strings

0 commit comments

Comments
 (0)