Skip to content

Commit aa05156

Browse files
authored
yacht: add exercise (#807)
* yacht: add exercise * yacht: fix typos * yacht exercise: refactored an example solution. * yacht exercise: added a new contributor. * yacht exercise: Moved contributor to the right key in config.json * yacht exercise: changed type of categories from string to keyword.
1 parent 6401849 commit aa05156

File tree

7 files changed

+303
-0
lines changed

7 files changed

+303
-0
lines changed

config.json

+10
Original file line numberDiff line numberDiff line change
@@ -1292,6 +1292,16 @@
12921292
],
12931293
"difficulty": 5,
12941294
"status": "beta"
1295+
},
1296+
{
1297+
"slug": "yacht",
1298+
"name": "Yacht",
1299+
"uuid": "a722b0da-7060-4dd5-930f-4fea566afebf",
1300+
"practices": [
1301+
"lists"
1302+
],
1303+
"prerequisites": [],
1304+
"difficulty": 5
12951305
}
12961306
],
12971307
"foregone": [
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,35 @@
1+
# Instructions
2+
3+
The dice game [Yacht][yacht] is from the same family as Poker Dice, Generala and particularly Yahtzee, of which it is a precursor.
4+
In the game, five dice are rolled and the result can be entered in any of twelve categories.
5+
The score of a throw of the dice depends on category chosen.
6+
7+
## Scores in Yacht
8+
9+
| Category | Score | Description | Example |
10+
| --------------- | ---------------------- | ---------------------------------------- | ------------------- |
11+
| Ones | 1 × number of ones | Any combination | 1 1 1 4 5 scores 3 |
12+
| Twos | 2 × number of twos | Any combination | 2 2 3 4 5 scores 4 |
13+
| Threes | 3 × number of threes | Any combination | 3 3 3 3 3 scores 15 |
14+
| Fours | 4 × number of fours | Any combination | 1 2 3 3 5 scores 0 |
15+
| Fives | 5 × number of fives | Any combination | 5 1 5 2 5 scores 15 |
16+
| Sixes | 6 × number of sixes | Any combination | 2 3 4 5 6 scores 6 |
17+
| Full House | Total of the dice | Three of one number and two of another | 3 3 3 5 5 scores 19 |
18+
| Four of a Kind | Total of the four dice | At least four dice showing the same face | 4 4 4 4 6 scores 16 |
19+
| Little Straight | 30 points | 1-2-3-4-5 | 1 2 3 4 5 scores 30 |
20+
| Big Straight | 30 points | 2-3-4-5-6 | 2 3 4 5 6 scores 30 |
21+
| Choice | Sum of the dice | Any combination | 2 3 3 4 6 scores 18 |
22+
| Yacht | 50 points | All five dice showing the same face | 4 4 4 4 4 scores 50 |
23+
24+
If the dice do not satisfy the requirements of a category, the score is zero.
25+
If, for example, _Four Of A Kind_ is entered in the _Yacht_ category, zero points are scored.
26+
A _Yacht_ scores zero if entered in the _Full House_ category.
27+
28+
## Task
29+
30+
Given a list of values for five dice and a category, your solution should return the score of the dice for that category.
31+
If the dice do not satisfy the requirements of the category your solution should return 0.
32+
You can assume that five values will always be presented, and the value of each will be between one and six inclusively.
33+
You should not assume that the dice are ordered.
34+
35+
[yacht]: https://en.wikipedia.org/wiki/Yacht_(dice_game)
+22
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,22 @@
1+
{
2+
"authors": [
3+
"SimaDovakin"
4+
],
5+
"contributors": [
6+
"verdammelt"
7+
],
8+
"files": {
9+
"solution": [
10+
"./yacht.lisp"
11+
],
12+
"test": [
13+
"./yacht-test.lisp"
14+
],
15+
"example": [
16+
"./.meta/example.lisp"
17+
]
18+
},
19+
"blurb": "Score a single throw of dice in the game Yacht.",
20+
"source": "James Kilfiger, using wikipedia",
21+
"source_url": "https://en.wikipedia.org/wiki/Yacht_(dice_game)"
22+
}
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,53 @@
1+
(defpackage :yacht
2+
(:use :cl)
3+
(:export :score))
4+
(in-package :yacht)
5+
6+
(defun hash-values (ht)
7+
(loop for v being each hash-value of ht collect v))
8+
9+
(defun frequencies (sequence)
10+
(let ((occurences (make-hash-table)))
11+
(reduce (lambda (acc n)
12+
(incf (gethash n acc 0))
13+
acc)
14+
sequence
15+
:initial-value occurences)))
16+
17+
(defun full-house (occurences)
18+
(let ((vals (hash-values occurences)))
19+
(equal '(2 3) (sort vals #'<))))
20+
21+
(defun four-of-a-kind-dice (occurences)
22+
(let ((pair nil))
23+
(maphash (lambda (key val)
24+
(when (>= val 4)
25+
(setf pair key)))
26+
occurences)
27+
pair))
28+
29+
(defun score (scores category)
30+
"Returns the score of the dice for the given category."
31+
(case category
32+
(:ones (count 1 scores))
33+
(:twos (* 2 (count 2 scores)))
34+
(:threes (* 3 (count 3 scores)))
35+
(:fours (* 4 (count 4 scores)))
36+
(:fives (* 5 (count 5 scores)))
37+
(:sixes (* 6 (count 6 scores)))
38+
(:full-house (if (full-house (frequencies scores))
39+
(reduce '+ scores)
40+
0))
41+
(:four-of-a-kind (let ((dice (four-of-a-kind-dice (frequencies scores))))
42+
(if dice (* 4 dice) 0)))
43+
(:little-straight (if (equal '(1 2 3 4 5) (sort scores #'<))
44+
30
45+
0))
46+
(:big-straight (if (equal '(2 3 4 5 6) (sort scores #'<))
47+
30
48+
0))
49+
(:choice (reduce '+ scores))
50+
(:yacht (if (= 1 (hash-table-count (frequencies scores)))
51+
50
52+
0))
53+
(t 0)))
+97
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,97 @@
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+
[3060e4a5-4063-4deb-a380-a630b43a84b6]
13+
description = "Yacht"
14+
15+
[15026df2-f567-482f-b4d5-5297d57769d9]
16+
description = "Not Yacht"
17+
18+
[36b6af0c-ca06-4666-97de-5d31213957a4]
19+
description = "Ones"
20+
21+
[023a07c8-6c6e-44d0-bc17-efc5e1b8205a]
22+
description = "Ones, out of order"
23+
24+
[7189afac-cccd-4a74-8182-1cb1f374e496]
25+
description = "No ones"
26+
27+
[793c4292-dd14-49c4-9707-6d9c56cee725]
28+
description = "Twos"
29+
30+
[dc41bceb-d0c5-4634-a734-c01b4233a0c6]
31+
description = "Fours"
32+
33+
[f6125417-5c8a-4bca-bc5b-b4b76d0d28c8]
34+
description = "Yacht counted as threes"
35+
36+
[464fc809-96ed-46e4-acb8-d44e302e9726]
37+
description = "Yacht of 3s counted as fives"
38+
39+
[d054227f-3a71-4565-a684-5c7e621ec1e9]
40+
description = "Fives"
41+
42+
[e8a036e0-9d21-443a-8b5f-e15a9e19a761]
43+
description = "Sixes"
44+
45+
[51cb26db-6b24-49af-a9ff-12f53b252eea]
46+
description = "Full house two small, three big"
47+
48+
[1822ca9d-f235-4447-b430-2e8cfc448f0c]
49+
description = "Full house three small, two big"
50+
51+
[b208a3fc-db2e-4363-a936-9e9a71e69c07]
52+
description = "Two pair is not a full house"
53+
54+
[b90209c3-5956-445b-8a0b-0ac8b906b1c2]
55+
description = "Four of a kind is not a full house"
56+
57+
[32a3f4ee-9142-4edf-ba70-6c0f96eb4b0c]
58+
description = "Yacht is not a full house"
59+
60+
[b286084d-0568-4460-844a-ba79d71d79c6]
61+
description = "Four of a Kind"
62+
63+
[f25c0c90-5397-4732-9779-b1e9b5f612ca]
64+
description = "Yacht can be scored as Four of a Kind"
65+
66+
[9f8ef4f0-72bb-401a-a871-cbad39c9cb08]
67+
description = "Full house is not Four of a Kind"
68+
69+
[b4743c82-1eb8-4a65-98f7-33ad126905cd]
70+
description = "Little Straight"
71+
72+
[7ac08422-41bf-459c-8187-a38a12d080bc]
73+
description = "Little Straight as Big Straight"
74+
75+
[97bde8f7-9058-43ea-9de7-0bc3ed6d3002]
76+
description = "Four in order but not a little straight"
77+
78+
[cef35ff9-9c5e-4fd2-ae95-6e4af5e95a99]
79+
description = "No pairs but not a little straight"
80+
81+
[fd785ad2-c060-4e45-81c6-ea2bbb781b9d]
82+
description = "Minimum is 1, maximum is 5, but not a little straight"
83+
84+
[35bd74a6-5cf6-431a-97a3-4f713663f467]
85+
description = "Big Straight"
86+
87+
[87c67e1e-3e87-4f3a-a9b1-62927822b250]
88+
description = "Big Straight as little straight"
89+
90+
[c1fa0a3a-40ba-4153-a42d-32bc34d2521e]
91+
description = "No pairs but not a big straight"
92+
93+
[207e7300-5d10-43e5-afdd-213e3ac8827d]
94+
description = "Choice"
95+
96+
[b524c0cf-32d2-4b40-8fb3-be3500f3f135]
97+
description = "Yacht as choice"
+78
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,78 @@
1+
;; Ensures that yacht.lisp and the testing library are always loaded
2+
(eval-when (:compile-toplevel :load-toplevel :execute)
3+
(load "yacht")
4+
(quicklisp-client:quickload :fiveam))
5+
6+
;; Defines the testing package with symbols from yacht and FiveAM in scope
7+
;; The `run-tests` function is exported for use by both the user and test-runner
8+
(defpackage :yacht-test
9+
(:use :cl :fiveam)
10+
(:export :run-tests))
11+
12+
;; Enter the testing package
13+
(in-package :yacht-test)
14+
15+
;; Define and enter a new FiveAM test-suite
16+
(def-suite* yacht-suite)
17+
18+
(test test-1 (is (equal 50 (yacht:score '(5 5 5 5 5) :yacht))))
19+
20+
(test test-2 (is (equal 0 (yacht:score '(1 3 3 2 5) :yacht))))
21+
22+
(test test-3 (is (equal 3 (yacht:score '(1 1 1 3 5) :ones))))
23+
24+
(test test-4 (is (equal 3 (yacht:score '(3 1 1 5 1) :ones))))
25+
26+
(test test-5 (is (equal 0 (yacht:score '(4 3 6 5 5) :ones))))
27+
28+
(test test-6 (is (equal 2 (yacht:score '(2 3 4 5 6) :twos))))
29+
30+
(test test-7 (is (equal 8 (yacht:score '(1 4 1 4 1) :fours))))
31+
32+
(test test-8 (is (equal 15 (yacht:score '(3 3 3 3 3) :threes))))
33+
34+
(test test-9 (is (equal 0 (yacht:score '(3 3 3 3 3) :fives))))
35+
36+
(test test-10 (is (equal 10 (yacht:score '(1 5 3 5 3) :fives))))
37+
38+
(test test-11 (is (equal 6 (yacht:score '(2 3 4 5 6) :sixes))))
39+
40+
(test test-12 (is (equal 16 (yacht:score '(2 2 4 4 4) :full-house))))
41+
42+
(test test-13 (is (equal 19 (yacht:score '(5 3 3 5 3) :full-house))))
43+
44+
(test test-14 (is (equal 0 (yacht:score '(2 2 4 4 5) :full-house))))
45+
46+
(test test-15 (is (equal 0 (yacht:score '(1 4 4 4 4) :full-house))))
47+
48+
(test test-16 (is (equal 0 (yacht:score '(2 2 2 2 2) :full-house))))
49+
50+
(test test-17 (is (equal 24 (yacht:score '(6 6 4 6 6) :four-of-a-kind))))
51+
52+
(test test-18 (is (equal 12 (yacht:score '(3 3 3 3 3) :four-of-a-kind))))
53+
54+
(test test-19 (is (equal 0 (yacht:score '(3 3 3 5 5) :four-of-a-kind))))
55+
56+
(test test-20 (is (equal 30 (yacht:score '(3 5 4 1 2) :little-straight))))
57+
58+
(test test-21 (is (equal 0 (yacht:score '(1 2 3 4 5) :big-straight))))
59+
60+
(test test-22 (is (equal 0 (yacht:score '(1 1 2 3 4) :little-straight))))
61+
62+
(test test-23 (is (equal 0 (yacht:score '(1 2 3 4 6) :little-straight))))
63+
64+
(test test-24 (is (equal 0 (yacht:score '(1 1 3 4 5) :little-straight))))
65+
66+
(test test-25 (is (equal 30 (yacht:score '(4 6 2 5 3) :big-straight))))
67+
68+
(test test-26 (is (equal 0 (yacht:score '(6 5 4 3 2) :little-straight))))
69+
70+
(test test-27 (is (equal 0 (yacht:score '(6 5 4 3 1) :big-straight))))
71+
72+
(test test-28 (is (equal 23 (yacht:score '(3 3 5 6 6) :choice))))
73+
74+
(test test-29 (is (equal 10 (yacht:score '(2 2 2 2 2) :choice))))
75+
76+
(defun run-tests (&optional (test-or-suite 'yacht-suite))
77+
"Provides human readable results of test run. Default to entire suite."
78+
(run! test-or-suite))

exercises/practice/yacht/yacht.lisp

+8
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,8 @@
1+
(defpackage :yacht
2+
(:use :cl)
3+
(:export :score))
4+
(in-package :yacht)
5+
6+
(defun score (scores category)
7+
"Returns the score of the dice for the given category."
8+
)

0 commit comments

Comments
 (0)