From 7898f740df3968739380514c9ac8b6308869aedf Mon Sep 17 00:00:00 2001 From: Elena Parovyshnaia Date: Mon, 9 Dec 2019 18:21:31 +0300 Subject: [PATCH 01/10] grade-school: make description match expectations https://github.com/exercism/problem-specifications/pull/1624 https://github.com/exercism/problem-specifications/issues/1623 --- exercises/grade-school/README.md | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) diff --git a/exercises/grade-school/README.md b/exercises/grade-school/README.md index 365535e1f..f4432571c 100644 --- a/exercises/grade-school/README.md +++ b/exercises/grade-school/README.md @@ -15,9 +15,12 @@ In the end, you should be able to: as 1, 2, 3, etc., and students within a grade should be sorted alphabetically by name. - "Who all is enrolled in school right now?" - - "Grade 1: Anna, Barb, and Charlie. Grade 2: Alex, Peter, and Zoe. - Grade 3…" - + - "Let me think. We have + Anna, Barb, and Charlie in grade 1, + Alex, Peter, and Zoe in grade 2 + and Jim in grade 5. + So the answer is: Anna, Barb, Charlie, Alex, Peter, Zoe and Jim" + Note that all our students only have one name. (It's a small town, what do you want?) From d737068ad57337538a9141e1f2dcd35ffc9bf741 Mon Sep 17 00:00:00 2001 From: Florian Keller Date: Sun, 22 Dec 2019 12:39:16 +0100 Subject: [PATCH 02/10] fix: Remove trailing spaces https://github.com/exercism/problem-specifications/pull/1627 --- exercises/grade-school/README.md | 8 ++++---- exercises/list-ops/README.md | 2 +- exercises/minesweeper/README.md | 2 +- 3 files changed, 6 insertions(+), 6 deletions(-) diff --git a/exercises/grade-school/README.md b/exercises/grade-school/README.md index f4432571c..3dcd88ff7 100644 --- a/exercises/grade-school/README.md +++ b/exercises/grade-school/README.md @@ -15,12 +15,12 @@ In the end, you should be able to: as 1, 2, 3, etc., and students within a grade should be sorted alphabetically by name. - "Who all is enrolled in school right now?" - - "Let me think. We have - Anna, Barb, and Charlie in grade 1, + - "Let me think. We have + Anna, Barb, and Charlie in grade 1, Alex, Peter, and Zoe in grade 2 - and Jim in grade 5. + and Jim in grade 5. So the answer is: Anna, Barb, Charlie, Alex, Peter, Zoe and Jim" - + Note that all our students only have one name. (It's a small town, what do you want?) diff --git a/exercises/list-ops/README.md b/exercises/list-ops/README.md index b7e856e1a..c7a6b5279 100644 --- a/exercises/list-ops/README.md +++ b/exercises/list-ops/README.md @@ -6,7 +6,7 @@ In functional languages list operations like `length`, `map`, and `reduce` are very common. Implement a series of basic list operations, without using existing functions. -The precise number and names of the operations to be implemented will be +The precise number and names of the operations to be implemented will be track dependent to avoid conflicts with existing names, but the general operations you will implement include: diff --git a/exercises/minesweeper/README.md b/exercises/minesweeper/README.md index a45d13da3..50e6f6176 100644 --- a/exercises/minesweeper/README.md +++ b/exercises/minesweeper/README.md @@ -10,7 +10,7 @@ In this exercise you have to create some code that counts the number of mines adjacent to a given empty square and replaces that square with the count. -The board is a rectangle composed of blank space (' ') characters. A mine +The board is a rectangle composed of blank space (' ') characters. A mine is represented by an asterisk ('\*') character. If a given space has no adjacent mines at all, leave that square blank. From 70706739194acad5febc4f956bc33c4dec97a65a Mon Sep 17 00:00:00 2001 From: Bruce Park Date: Wed, 15 Apr 2020 15:50:10 -0700 Subject: [PATCH 03/10] simple-linked-list: update source Previous link was no longer working properly, so use web.archive.org https://github.com/exercism/problem-specifications/pull/1648 --- exercises/simple-linked-list/README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/exercises/simple-linked-list/README.md b/exercises/simple-linked-list/README.md index 5166740cc..a3d33a63a 100644 --- a/exercises/simple-linked-list/README.md +++ b/exercises/simple-linked-list/README.md @@ -95,7 +95,7 @@ one, head over there and create an issue. We'll do our best to help you! ## Source -Inspired by 'Data Structures and Algorithms with Object-Oriented Design Patterns in Ruby', singly linked-lists. [http://www.brpreiss.com/books/opus8/html/page96.html#SECTION004300000000000000000](http://www.brpreiss.com/books/opus8/html/page96.html#SECTION004300000000000000000) +Inspired by 'Data Structures and Algorithms with Object-Oriented Design Patterns in Ruby', singly linked-lists. [https://web.archive.org/web/20160414064110/http://www.brpreiss.com/books/opus8/](https://web.archive.org/web/20160414064110/http://www.brpreiss.com/books/opus8/) ## Submitting Incomplete Solutions It's possible to submit an incomplete solution so you can see how others have completed the exercise. From 554505ac21108cb22d20b72b2568c2c3b8f44b73 Mon Sep 17 00:00:00 2001 From: Tejas Bubane Date: Sat, 18 Apr 2020 17:09:13 +0530 Subject: [PATCH 04/10] simple-linked-list: Fix metadata source_url Previous web.archive.org link pointed to the book homepage. Change it to point to simple-linked-list page. https://github.com/exercism/problem-specifications/pull/1649 --- exercises/simple-linked-list/README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/exercises/simple-linked-list/README.md b/exercises/simple-linked-list/README.md index a3d33a63a..4330c07a8 100644 --- a/exercises/simple-linked-list/README.md +++ b/exercises/simple-linked-list/README.md @@ -95,7 +95,7 @@ one, head over there and create an issue. We'll do our best to help you! ## Source -Inspired by 'Data Structures and Algorithms with Object-Oriented Design Patterns in Ruby', singly linked-lists. [https://web.archive.org/web/20160414064110/http://www.brpreiss.com/books/opus8/](https://web.archive.org/web/20160414064110/http://www.brpreiss.com/books/opus8/) +Inspired by 'Data Structures and Algorithms with Object-Oriented Design Patterns in Ruby', singly linked-lists. [https://web.archive.org/web/20160731005714/http://brpreiss.com/books/opus8/html/page96.html](https://web.archive.org/web/20160731005714/http://brpreiss.com/books/opus8/html/page96.html) ## Submitting Incomplete Solutions It's possible to submit an incomplete solution so you can see how others have completed the exercise. From 615ce20e997dc5a0dfc77da7927dab77adfda1e7 Mon Sep 17 00:00:00 2001 From: Jubilee <46493976+workingjubilee@users.noreply.github.com> Date: Thu, 23 Apr 2020 01:51:01 -0700 Subject: [PATCH 05/10] luhn: Fix apophenia error slowing student progress apophenia - noun "the tendency to perceive a connection or meaningful pattern between unrelated or random things" compare: pareidolia - noun "to perceive a specific, often meaningful image in a random or ambiguous visual pattern" - Merriam Webster's https://github.com/exercism/problem-specifications/pull/1650 --- exercises/luhn/README.md | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/exercises/luhn/README.md b/exercises/luhn/README.md index 52dc89393..ab4828268 100644 --- a/exercises/luhn/README.md +++ b/exercises/luhn/README.md @@ -19,27 +19,27 @@ are disallowed. ## Example 1: valid credit card number ```text -4539 1488 0343 6467 +4539 3195 0343 6467 ``` The first step of the Luhn algorithm is to double every second digit, starting from the right. We will be doubling ```text -4_3_ 1_8_ 0_4_ 6_6_ +4_3_ 3_9_ 0_4_ 6_6_ ``` If doubling the number results in a number greater than 9 then subtract 9 from the product. The results of our doubling: ```text -8569 2478 0383 3437 +8569 6195 0383 3437 ``` Then sum all of the digits: ```text -8+5+6+9+2+4+7+8+0+3+8+3+3+4+3+7 = 80 +8+5+6+9+6+1+9+5+0+3+8+3+3+4+3+7 = 80 ``` If the sum is evenly divisible by 10, then the number is valid. This number is valid! From cac36736a74d6d70246f365ddd47f1129eded3b5 Mon Sep 17 00:00:00 2001 From: Charles Ross Date: Thu, 30 Apr 2020 15:35:05 -0700 Subject: [PATCH 06/10] simple-cipher: Update key requirements The test suite is testing against the key having only lowercase letters, not alphanumeric. https://github.com/exercism/problem-specifications/pull/1653 --- exercises/simple-cipher/README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/exercises/simple-cipher/README.md b/exercises/simple-cipher/README.md index 7e1a0e208..0ca8407bb 100644 --- a/exercises/simple-cipher/README.md +++ b/exercises/simple-cipher/README.md @@ -61,7 +61,7 @@ substitution cipher a little more fault tolerant by providing a source of randomness and ensuring that the key contains only lowercase letters. If someone doesn't submit a key at all, generate a truly random key of -at least 100 alphanumeric characters in length. +at least 100 lowercase characters in length. ## Extensions From 3e66bc567b1675c43d4e5a2b0517d882212f2647 Mon Sep 17 00:00:00 2001 From: DmitrySamoylov <56959852+DmitrySamoylov@users.noreply.github.com> Date: Wed, 3 Jun 2020 06:21:08 +0700 Subject: [PATCH 07/10] palindrome-products: specify product of two numbers For me it took a while to understand that we calculate product of exactly two numbers. BTW in the [original problem](https://projecteuler.net/problem=4) it is stated clearly. https://github.com/exercism/problem-specifications/pull/1662 --- exercises/palindrome-products/README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/exercises/palindrome-products/README.md b/exercises/palindrome-products/README.md index 5d28fd1f0..5a6b05426 100644 --- a/exercises/palindrome-products/README.md +++ b/exercises/palindrome-products/README.md @@ -6,7 +6,7 @@ A palindromic number is a number that remains the same when its digits are reversed. For example, `121` is a palindromic number but `112` is not. Given a range of numbers, find the largest and smallest palindromes which -are products of numbers within that range. +are products of two numbers within that range. Your solution should return the largest and smallest palindromes, along with the factors of each within the range. If the largest or smallest palindrome has more From 5eda3b6be4be060b7fd178396ad6489a0eb118e5 Mon Sep 17 00:00:00 2001 From: Colin Caine Date: Fri, 12 Jun 2020 17:19:20 +0100 Subject: [PATCH 08/10] robot-name: remove dead link gSchool.it is now a domain parking spot https://github.com/exercism/problem-specifications/pull/1663 --- exercises/robot-name/README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/exercises/robot-name/README.md b/exercises/robot-name/README.md index 79784e53d..1d1910503 100644 --- a/exercises/robot-name/README.md +++ b/exercises/robot-name/README.md @@ -90,7 +90,7 @@ one, head over there and create an issue. We'll do our best to help you! ## Source -A debugging session with Paul Blackwell at gSchool. [http://gschool.it](http://gschool.it) +A debugging session with Paul Blackwell at gSchool. ## Submitting Incomplete Solutions It's possible to submit an incomplete solution so you can see how others have completed the exercise. From 3c92cc654d4d94f2a74b88122d8487cffc201998 Mon Sep 17 00:00:00 2001 From: Kirill Artamonov Date: Wed, 14 Oct 2020 09:54:19 +0200 Subject: [PATCH 09/10] resistor-color/resistor-color-duo: extend exercise explanation (partial copy from resistor-color-duo) https://github.com/exercism/problem-specifications/pull/1667 --- exercises/resistor-color-duo/README.md | 12 +++++++++--- 1 file changed, 9 insertions(+), 3 deletions(-) diff --git a/exercises/resistor-color-duo/README.md b/exercises/resistor-color-duo/README.md index e774b45b4..2f9e495fb 100644 --- a/exercises/resistor-color-duo/README.md +++ b/exercises/resistor-color-duo/README.md @@ -1,13 +1,19 @@ # Resistor Color Duo -If you want to build something using a Raspberry Pi, you'll probably use _resistors_. For this exercise, you need to know two things about them: +If you want to build something using a Raspberry Pi, you'll probably use _resistors_. +For this exercise, you need to know two things about them: * Each resistor has a resistance value. * Resistors are small - so small in fact that if you printed the resistance value on them, it would be hard to read. -To get around this problem, manufacturers print color-coded bands onto the resistors to denote their resistance values. Each band has a position and a numeric value. For example, if they printed a brown band (value 1) followed by a green band (value 5), it would translate to the number 15. -In this exercise you are going to create a helpful program so that you don't have to remember the values of the bands. The program will take color names as input and output a two digit number, even if the input is more than two colors! +To get around this problem, manufacturers print color-coded bands onto the resistors to denote their resistance values. +Each band has a position and a numeric value. +The first 2 bands of a resistor have a simple encoding scheme: each color maps to a single number. +For example, if they printed a brown band (value 1) followed by a green band (value 5), it would translate to the number 15. + +In this exercise you are going to create a helpful program so that you don't have to remember the values of the bands. +The program will take color names as input and output a two digit number, even if the input is more than two colors! The band colors are encoded as follows: From 46a30c45b2616f084b177a4048c11a19254bff3f Mon Sep 17 00:00:00 2001 From: ee7 <45465154+ee7@users.noreply.github.com> Date: Thu, 15 Oct 2020 15:08:08 +0200 Subject: [PATCH 10/10] perfect-numbers: 'natural number' -> 'positive integer' There is no convention whether zero is a natural number, so let's avoid the issue. For example, see: - https://mathworld.wolfram.com/NaturalNumber.html - https://en.wikipedia.org/wiki/Natural_number - https://math.stackexchange.com/questions/283/is-0-a-natural-number The previous wording of ``` "description": "Zero is rejected (not a natural number)", ``` could be especially jarring for some tracks. For example, Nim defines `Natural` and `Positive` types, and `Natural` includes 0. See: - https://nim-lang.github.io/Nim/system.html#Natural Co-authored-by: Sascha Mann https://github.com/exercism/problem-specifications/pull/1691 --- exercises/perfect-numbers/README.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/exercises/perfect-numbers/README.md b/exercises/perfect-numbers/README.md index ad0e14e3f..3f6356a88 100644 --- a/exercises/perfect-numbers/README.md +++ b/exercises/perfect-numbers/README.md @@ -1,9 +1,9 @@ # Perfect Numbers Determine if a number is perfect, abundant, or deficient based on -Nicomachus' (60 - 120 CE) classification scheme for natural numbers. +Nicomachus' (60 - 120 CE) classification scheme for positive integers. -The Greek mathematician [Nicomachus](https://en.wikipedia.org/wiki/Nicomachus) devised a classification scheme for natural numbers, identifying each as belonging uniquely to the categories of **perfect**, **abundant**, or **deficient** based on their [aliquot sum](https://en.wikipedia.org/wiki/Aliquot_sum). The aliquot sum is defined as the sum of the factors of a number not including the number itself. For example, the aliquot sum of 15 is (1 + 3 + 5) = 9 +The Greek mathematician [Nicomachus](https://en.wikipedia.org/wiki/Nicomachus) devised a classification scheme for positive integers, identifying each as belonging uniquely to the categories of **perfect**, **abundant**, or **deficient** based on their [aliquot sum](https://en.wikipedia.org/wiki/Aliquot_sum). The aliquot sum is defined as the sum of the factors of a number not including the number itself. For example, the aliquot sum of 15 is (1 + 3 + 5) = 9 - **Perfect**: aliquot sum = number - 6 is a perfect number because (1 + 2 + 3) = 6