Skip to content

Commit

Permalink
Add exercise eliuds-eggs
Browse files Browse the repository at this point in the history
  • Loading branch information
senekor committed Mar 24, 2024
1 parent b57a883 commit d04c778
Show file tree
Hide file tree
Showing 12 changed files with 169 additions and 1 deletion.
9 changes: 9 additions & 0 deletions config.json
Original file line number Diff line number Diff line change
Expand Up @@ -1533,6 +1533,15 @@
"prerequisites": [],
"difficulty": 4,
"topics": []
},
{
"slug": "eliuds-eggs",
"name": "Eliuds Eggs",
"uuid": "2d738c77-8dde-437a-bf42-ed5542a414d1",
"practices": [],
"prerequisites": [],
"difficulty": 1,
"topics": []
}
],
"foregone": [
Expand Down
8 changes: 8 additions & 0 deletions exercises/practice/eliuds-eggs/.docs/instructions.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
# Instructions

Your task is to count the number of 1 bits in the binary representation of a number.

## Restrictions

Keep your hands off that bit-count functionality provided by your standard library!
Solve this one yourself using other basic tools instead.
47 changes: 47 additions & 0 deletions exercises/practice/eliuds-eggs/.docs/introduction.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,47 @@
# Introduction

Your friend Eliud inherited a farm from her grandma Tigist.
Her granny was an inventor and had a tendency to build things in an overly complicated manner.
The chicken coop has a digital display showing an encoded number representing the positions of all eggs that could be picked up.

Eliud is asking you to write a program that shows the actual number of eggs in the coop.

The position information encoding is calculated as follows:

1. Scan the potential egg-laying spots and mark down a `1` for an existing egg or a `0` for an empty spot.
2. Convert the number from binary to decimal.
3. Show the result on the display.

Example 1:

```text
Chicken Coop:
_ _ _ _ _ _ _
|E| |E|E| | |E|
Resulting Binary:
1 0 1 1 0 0 1
Decimal number on the display:
89
Actual eggs in the coop:
4
```

Example 2:

```text
Chicken Coop:
_ _ _ _ _ _ _ _
| | | |E| | | | |
Resulting Binary:
0 0 0 1 0 0 0 0
Decimal number on the display:
16
Actual eggs in the coop:
1
```
2 changes: 2 additions & 0 deletions exercises/practice/eliuds-eggs/.gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
/target
/Cargo.lock
18 changes: 18 additions & 0 deletions exercises/practice/eliuds-eggs/.meta/config.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
{
"authors": ["senekor"],
"files": {
"solution": [
"src/lib.rs",
"Cargo.toml"
],
"test": [
"tests/eliuds-eggs.rs"
],
"example": [
".meta/example.rs"
]
},
"blurb": "Help Eliud count the number of eggs in her chicken coop by counting the number of 1 bits in a binary representation.",
"source": "Christian Willner, Eric Willigers",
"source_url": "https://forum.exercism.org/t/new-exercise-suggestion-pop-count/7632/5"
}
3 changes: 3 additions & 0 deletions exercises/practice/eliuds-eggs/.meta/example.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
pub fn egg_count(display_value: u32) -> usize {
(0..32).filter(|i| display_value & (1 << i) != 0).count()
}
14 changes: 14 additions & 0 deletions exercises/practice/eliuds-eggs/.meta/test_template.tera
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
use {{ crate_name }}::*;

{% for test in cases %}
#[test]
{% if loop.index != 1 -%}
#[ignore]
{% endif -%}
fn test_{{ test.description | slugify | replace(from="-", to="_") }}() {
let input = {{ test.input.number }};
let output = {{ fn_names[0] }}(input);
let expected = {{ test.expected | json_encode() }};
assert_eq!(output, expected);
}
{% endfor -%}
22 changes: 22 additions & 0 deletions exercises/practice/eliuds-eggs/.meta/tests.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
# This is an auto-generated file.
#
# Regenerating this file via `configlet sync` will:
# - Recreate every `description` key/value pair
# - Recreate every `reimplements` key/value pair, where they exist in problem-specifications
# - Remove any `include = true` key/value pair (an omitted `include` key implies inclusion)
# - Preserve any other key/value pair
#
# As user-added comments (using the # character) will be removed when this file
# is regenerated, comments can be added via a `comment` key.

[559e789d-07d1-4422-9004-3b699f83bca3]
description = "0 eggs"

[97223282-f71e-490c-92f0-b3ec9e275aba]
description = "1 egg"

[1f8fd18f-26e9-4144-9a0e-57cdfc4f4ff5]
description = "4 eggs"

[0c18be92-a498-4ef2-bcbb-28ac4b06cb81]
description = "13 eggs"
6 changes: 6 additions & 0 deletions exercises/practice/eliuds-eggs/Cargo.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
[package]
edition = "2021"
name = "eliuds_eggs"
version = "1.0.0"

[dependencies]
3 changes: 3 additions & 0 deletions exercises/practice/eliuds-eggs/src/lib.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
pub fn egg_count(display_value: u32) -> usize {
todo!("count the eggs in {display_value}")
}
36 changes: 36 additions & 0 deletions exercises/practice/eliuds-eggs/tests/eliuds-eggs.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,36 @@
use eliuds_eggs::*;

#[test]
fn test_0_eggs() {
let input = 0;
let output = egg_count(input);
let expected = 0;
assert_eq!(output, expected);
}

#[test]
#[ignore]
fn test_1_egg() {
let input = 16;
let output = egg_count(input);
let expected = 1;
assert_eq!(output, expected);
}

#[test]
#[ignore]
fn test_4_eggs() {
let input = 89;
let output = egg_count(input);
let expected = 4;
assert_eq!(output, expected);
}

#[test]
#[ignore]
fn test_13_eggs() {
let input = 2000000000;
let output = egg_count(input);
let expected = 13;
assert_eq!(output, expected);
}

0 comments on commit d04c778

Please sign in to comment.