Skip to content

Commit 42d3c37

Browse files
Add pig-latin exercise (#66)
1 parent 7291127 commit 42d3c37

File tree

8 files changed

+309
-0
lines changed

8 files changed

+309
-0
lines changed

config.json

Lines changed: 8 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -441,6 +441,14 @@
441441
"prerequisites": [],
442442
"difficulty": 7
443443
},
444+
{
445+
"slug": "pig-latin",
446+
"name": "Pig Latin",
447+
"uuid": "c0bd0c12-6ca9-424b-8300-adfda73aaaf4",
448+
"practices": [],
449+
"prerequisites": [],
450+
"difficulty": 7
451+
},
444452
{
445453
"slug": "rail-fence-cipher",
446454
"name": "Rail Fence Cipher",
Lines changed: 46 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,46 @@
1+
# Instructions
2+
3+
Your task is to translate text from English to Pig Latin.
4+
The translation is defined using four rules, which look at the pattern of vowels and consonants at the beginning of a word.
5+
These rules look at each word's use of vowels and consonants:
6+
7+
- vowels: the letters `a`, `e`, `i`, `o`, and `u`
8+
- consonants: the other 21 letters of the English alphabet
9+
10+
## Rule 1
11+
12+
If a word begins with a vowel, or starts with `"xr"` or `"yt"`, add an `"ay"` sound to the end of the word.
13+
14+
For example:
15+
16+
- `"apple"` -> `"appleay"` (starts with vowel)
17+
- `"xray"` -> `"xrayay"` (starts with `"xr"`)
18+
- `"yttria"` -> `"yttriaay"` (starts with `"yt"`)
19+
20+
## Rule 2
21+
22+
If a word begins with one or more consonants, first move those consonants to the end of the word and then add an `"ay"` sound to the end of the word.
23+
24+
For example:
25+
26+
- `"pig"` -> `"igp"` -> `"igpay"` (starts with single consonant)
27+
- `"chair"` -> `"airch"` -> `"airchay"` (starts with multiple consonants)
28+
- `"thrush"` -> `"ushthr"` -> `"ushthray"` (starts with multiple consonants)
29+
30+
## Rule 3
31+
32+
If a word starts with zero or more consonants followed by `"qu"`, first move those consonants (if any) and the `"qu"` part to the end of the word, and then add an `"ay"` sound to the end of the word.
33+
34+
For example:
35+
36+
- `"quick"` -> `"ickqu"` -> `"ickquay"` (starts with `"qu"`, no preceding consonants)
37+
- `"square"` -> `"aresqu"` -> `"aresquay"` (starts with one consonant followed by `"qu`")
38+
39+
## Rule 4
40+
41+
If a word starts with one or more consonants followed by `"y"`, first move the consonants preceding the `"y"`to the end of the word, and then add an `"ay"` sound to the end of the word.
42+
43+
Some examples:
44+
45+
- `"my"` -> `"ym"` -> `"ymay"` (starts with single consonant followed by `"y"`)
46+
- `"rhythm"` -> `"ythmrh"` -> `"ythmrhay"` (starts with multiple consonants followed by `"y"`)
Lines changed: 8 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,8 @@
1+
# Introduction
2+
3+
Your parents have challenged you and your sibling to a game of two-on-two basketball.
4+
Confident they'll win, they let you score the first couple of points, but then start taking over the game.
5+
Needing a little boost, you start speaking in [Pig Latin][pig-latin], which is a made-up children's language that's difficult for non-children to understand.
6+
This will give you the edge to prevail over your parents!
7+
8+
[pig-latin]: https://en.wikipedia.org/wiki/Pig_latin
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+
"pig_latin.fut"
8+
],
9+
"test": [
10+
"test.fut"
11+
],
12+
"example": [
13+
".meta/example.fut"
14+
]
15+
},
16+
"blurb": "Implement a program that translates from English to Pig Latin.",
17+
"source": "The Pig Latin exercise at Test First Teaching by Ultrasaurus",
18+
"source_url": "https://github.com/ultrasaurus/test-first-teaching/blob/master/learn_ruby/pig_latin/"
19+
}
Lines changed: 29 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,29 @@
1+
2+
3+
def is_consonant(letter: u8): bool =
4+
let vowels = 0x1104111 -- bitset representing a e i o u y
5+
in
6+
vowels & (1 << i32.u8 (letter - 'a')) == 0
7+
8+
-- word begins with a vowel, or starts with `"xr"` or `"yt"`
9+
def begins_with_vowel [n] (word: [n]u8): bool =
10+
if is_consonant word[0] then n > 1 && word[0] == 'x' && word[1] == 'r' else
11+
word[0] != 'y' || (n > 1 && word[1] == 't')
12+
13+
def render [n] (word: [n]u8) (index: i64): []u8 =
14+
word[index:] ++ word[:index] ++ "ay"
15+
16+
def translate_word [n] (word: [n]u8): []u8 =
17+
if begins_with_vowel word then render word 0 else
18+
let index = loop index = 1 while index < n && is_consonant word[index] do
19+
index + 1
20+
in
21+
if index == n || word[index - 1] != 'q' || word[index] != 'u' then render word index else
22+
render word (index + 1)
23+
24+
def translate [n] (phrase: [n]u8): []u8 =
25+
let (result, _) = loop (result, begin) = ("", 0) for index < n + 1 do
26+
if index < n && phrase[index] - 'a' < 26 then (result, begin) else
27+
(result ++ " " ++ translate_word phrase[begin:index], index + 1)
28+
in
29+
result[1:]
Lines changed: 79 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,79 @@
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+
[11567f84-e8c6-4918-aedb-435f0b73db57]
13+
description = "ay is added to words that start with vowels -> word beginning with a"
14+
15+
[f623f581-bc59-4f45-9032-90c3ca9d2d90]
16+
description = "ay is added to words that start with vowels -> word beginning with e"
17+
18+
[7dcb08b3-23a6-4e8a-b9aa-d4e859450d58]
19+
description = "ay is added to words that start with vowels -> word beginning with i"
20+
21+
[0e5c3bff-266d-41c8-909f-364e4d16e09c]
22+
description = "ay is added to words that start with vowels -> word beginning with o"
23+
24+
[614ba363-ca3c-4e96-ab09-c7320799723c]
25+
description = "ay is added to words that start with vowels -> word beginning with u"
26+
27+
[bf2538c6-69eb-4fa7-a494-5a3fec911326]
28+
description = "ay is added to words that start with vowels -> word beginning with a vowel and followed by a qu"
29+
30+
[e5be8a01-2d8a-45eb-abb4-3fcc9582a303]
31+
description = "first letter and ay are moved to the end of words that start with consonants -> word beginning with p"
32+
33+
[d36d1e13-a7ed-464d-a282-8820cb2261ce]
34+
description = "first letter and ay are moved to the end of words that start with consonants -> word beginning with k"
35+
36+
[d838b56f-0a89-4c90-b326-f16ff4e1dddc]
37+
description = "first letter and ay are moved to the end of words that start with consonants -> word beginning with x"
38+
39+
[bce94a7a-a94e-4e2b-80f4-b2bb02e40f71]
40+
description = "first letter and ay are moved to the end of words that start with consonants -> word beginning with q without a following u"
41+
42+
[e59dbbe8-ccee-4619-a8e9-ce017489bfc0]
43+
description = "first letter and ay are moved to the end of words that start with consonants -> word beginning with consonant and vowel containing qu"
44+
45+
[c01e049a-e3e2-451c-bf8e-e2abb7e438b8]
46+
description = "some letter clusters are treated like a single consonant -> word beginning with ch"
47+
48+
[9ba1669e-c43f-4b93-837a-cfc731fd1425]
49+
description = "some letter clusters are treated like a single consonant -> word beginning with qu"
50+
51+
[92e82277-d5e4-43d7-8dd3-3a3b316c41f7]
52+
description = "some letter clusters are treated like a single consonant -> word beginning with qu and a preceding consonant"
53+
54+
[79ae4248-3499-4d5b-af46-5cb05fa073ac]
55+
description = "some letter clusters are treated like a single consonant -> word beginning with th"
56+
57+
[e0b3ae65-f508-4de3-8999-19c2f8e243e1]
58+
description = "some letter clusters are treated like a single consonant -> word beginning with thr"
59+
60+
[20bc19f9-5a35-4341-9d69-1627d6ee6b43]
61+
description = "some letter clusters are treated like a single consonant -> word beginning with sch"
62+
63+
[54b796cb-613d-4509-8c82-8fbf8fc0af9e]
64+
description = "some letter clusters are treated like a single vowel -> word beginning with yt"
65+
66+
[8c37c5e1-872e-4630-ba6e-d20a959b67f6]
67+
description = "some letter clusters are treated like a single vowel -> word beginning with xr"
68+
69+
[a4a36d33-96f3-422c-a233-d4021460ff00]
70+
description = "position of y in a word determines if it is a consonant or a vowel -> y is treated like a consonant at the beginning of a word"
71+
72+
[adc90017-1a12-4100-b595-e346105042c7]
73+
description = "position of y in a word determines if it is a consonant or a vowel -> y is treated like a vowel at the end of a consonant cluster"
74+
75+
[29b4ca3d-efe5-4a95-9a54-8467f2e5e59a]
76+
description = "position of y in a word determines if it is a consonant or a vowel -> y as second letter in two letter word"
77+
78+
[44616581-5ce3-4a81-82d0-40c7ab13d2cf]
79+
description = "phrases are translated -> a whole phrase"
Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+
def translate (phrase: []u8): []u8 = ???

exercises/practice/pig-latin/test.fut

Lines changed: 119 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,119 @@
1+
import "pig_latin"
2+
3+
-- word beginning with a
4+
-- ==
5+
-- input { "apple" }
6+
-- output { "appleay" }
7+
8+
-- word beginning with e
9+
-- ==
10+
-- input { "ear" }
11+
-- output { "earay" }
12+
13+
-- word beginning with i
14+
-- ==
15+
-- input { "igloo" }
16+
-- output { "iglooay" }
17+
18+
-- word beginning with o
19+
-- ==
20+
-- input { "object" }
21+
-- output { "objectay" }
22+
23+
-- word beginning with u
24+
-- ==
25+
-- input { "under" }
26+
-- output { "underay" }
27+
28+
-- word beginning with a vowel and followed by a qu
29+
-- ==
30+
-- input { "equal" }
31+
-- output { "equalay" }
32+
33+
-- word beginning with p
34+
-- ==
35+
-- input { "pig" }
36+
-- output { "igpay" }
37+
38+
-- word beginning with k
39+
-- ==
40+
-- input { "koala" }
41+
-- output { "oalakay" }
42+
43+
-- word beginning with x
44+
-- ==
45+
-- input { "xenon" }
46+
-- output { "enonxay" }
47+
48+
-- word beginning with q without a following u
49+
-- ==
50+
-- input { "qat" }
51+
-- output { "atqay" }
52+
53+
-- word beginning with consonant and vowel containing qu
54+
-- ==
55+
-- input { "liquid" }
56+
-- output { "iquidlay" }
57+
58+
-- word beginning with ch
59+
-- ==
60+
-- input { "chair" }
61+
-- output { "airchay" }
62+
63+
-- word beginning with qu
64+
-- ==
65+
-- input { "queen" }
66+
-- output { "eenquay" }
67+
68+
-- word beginning with qu and a preceding consonant
69+
-- ==
70+
-- input { "square" }
71+
-- output { "aresquay" }
72+
73+
-- word beginning with th
74+
-- ==
75+
-- input { "therapy" }
76+
-- output { "erapythay" }
77+
78+
-- word beginning with thr
79+
-- ==
80+
-- input { "thrush" }
81+
-- output { "ushthray" }
82+
83+
-- word beginning with sch
84+
-- ==
85+
-- input { "school" }
86+
-- output { "oolschay" }
87+
88+
-- word beginning with yt
89+
-- ==
90+
-- input { "yttria" }
91+
-- output { "yttriaay" }
92+
93+
-- word beginning with xr
94+
-- ==
95+
-- input { "xray" }
96+
-- output { "xrayay" }
97+
98+
-- y is treated like a consonant at the beginning of a word
99+
-- ==
100+
-- input { "yellow" }
101+
-- output { "ellowyay" }
102+
103+
-- y is treated like a vowel at the end of a consonant cluster
104+
-- ==
105+
-- input { "rhythm" }
106+
-- output { "ythmrhay" }
107+
108+
-- y as second letter in two letter word
109+
-- ==
110+
-- input { "my" }
111+
-- output { "ymay" }
112+
113+
-- a whole phrase
114+
-- ==
115+
-- input { "quick fast run" }
116+
-- output { "ickquay astfay unray" }
117+
118+
def main (phrase: []u8): []u8 =
119+
translate phrase

0 commit comments

Comments
 (0)