Skip to content

Commit

Permalink
Add pop-count (#940) (#944)
Browse files Browse the repository at this point in the history
* Add pop-count (#940)

* Address PR comments

* Update exercises/practice/pop-count/test_pop_count.c

* Update bin/run-tests

---------

Co-authored-by: Ryan Hartlage <[email protected]>
  • Loading branch information
ahans and ryanplusplus authored Jan 28, 2024
1 parent 54d0376 commit 385e057
Show file tree
Hide file tree
Showing 14 changed files with 4,029 additions and 0 deletions.
13 changes: 13 additions & 0 deletions config.json
Original file line number Diff line number Diff line change
Expand Up @@ -1027,6 +1027,19 @@
"control_flow_loops",
"strings"
]
},
{
"slug": "pop-count",
"name": "Eliud's Eggs",
"uuid": "8a813e24-6263-437d-a610-7f5da1456b7f",
"practices": [],
"prerequisites": [],
"difficulty": 2,
"topics": [
"bitwise_operations",
"control_flow_if_statements",
"control_flow_loops"
]
}
]
},
Expand Down
8 changes: 8 additions & 0 deletions exercises/practice/pop-count/.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/pop-count/.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
```
21 changes: 21 additions & 0 deletions exercises/practice/pop-count/.meta/config.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
{
"authors": [
"ahans"
],
"files": {
"solution": [
"pop_count.c",
"pop_count.h"
],
"test": [
"test_pop_count.c"
],
"example": [
".meta/example.c",
".meta/example.h"
]
},
"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"
}
11 changes: 11 additions & 0 deletions exercises/practice/pop-count/.meta/example.c
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
#include "pop_count.h"

unsigned int egg_count(unsigned int value)
{
unsigned int count = 0;
while (value != 0) {
count += value & 1;
value = value >> 1;
}
return count;
}
6 changes: 6 additions & 0 deletions exercises/practice/pop-count/.meta/example.h
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
#ifndef POP_COUNT_H
#define POP_COUNT_H

unsigned int egg_count(unsigned int value);

#endif
22 changes: 22 additions & 0 deletions exercises/practice/pop-count/.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"
37 changes: 37 additions & 0 deletions exercises/practice/pop-count/makefile
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
### If you wish to use extra libraries (math.h for instance),
### add their flags here (-lm in our case) in the "LIBS" variable.

LIBS = -lm

###
CFLAGS = -std=c99
CFLAGS += -g
CFLAGS += -Wall
CFLAGS += -Wextra
CFLAGS += -pedantic
CFLAGS += -Werror
CFLAGS += -Wmissing-declarations
CFLAGS += -DUNITY_SUPPORT_64 -DUNITY_OUTPUT_COLOR

ASANFLAGS = -fsanitize=address
ASANFLAGS += -fno-common
ASANFLAGS += -fno-omit-frame-pointer

.PHONY: test
test: tests.out
@./tests.out

.PHONY: memcheck
memcheck: ./*.c ./*.h
@echo Compiling $@
@$(CC) $(ASANFLAGS) $(CFLAGS) test-framework/unity.c ./*.c -o memcheck.out $(LIBS)
@./memcheck.out
@echo "Memory check passed"

.PHONY: clean
clean:
rm -rf *.o *.out *.out.dSYM

tests.out: ./*.c ./*.h
@echo Compiling $@
@$(CC) $(CFLAGS) test-framework/unity.c ./*.c -o tests.out $(LIBS)
1 change: 1 addition & 0 deletions exercises/practice/pop-count/pop_count.c
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
#include "pop_count.h"
4 changes: 4 additions & 0 deletions exercises/practice/pop-count/pop_count.h
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
#ifndef POP_COUNT_H
#define POP_COUNT_H

#endif
Loading

0 comments on commit 385e057

Please sign in to comment.