-
Notifications
You must be signed in to change notification settings - Fork 1.8k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Bowling challenge #1604
Open
carolrs
wants to merge
5
commits into
makersacademy:main
Choose a base branch
from
carolrs:main
base: main
Could not load branches
Branch not found: {{ refName }}
Loading
Could not load tags
Nothing to show
Loading
Are you sure you want to change the base?
Some commits from the old base branch may be removed from the timeline,
and old review comments may become outdated.
Open
Bowling challenge #1604
Changes from all commits
Commits
Show all changes
5 commits
Select commit
Hold shift + click to select a range
File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,2 +1,3 @@ | ||
/**/.DS_Store | ||
node_modules | ||
node_modules/ | ||
coverage/ |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,91 +1,70 @@ | ||
# Bowling Challenge | ||
|
||
Bowling Challenge | ||
================= | ||
This repository contains a JavaScript implementation of a bowling scorecard. The purpose of this project is to count and sum the scores of a bowling game for one player. It consists of 10 frames, and the player tries to knock down 10 pins in each frame. The score of a frame is determined by the number of knocked down pins plus bonuses for strikes and spares. | ||
|
||
* Feel free to use google, your notes, books, etc. but work on your own | ||
* If you refer to the solution of another coach or student, please put a link to that in your README | ||
* If you have a partial solution, **still check in a partial solution** | ||
* You must submit a pull request to this repo with your code by 9am Monday week | ||
## Getting Started | ||
|
||
## The Task | ||
To use the bowling scorecard, follow the steps below: | ||
|
||
**THIS IS NOT A BOWLING GAME, IT IS A BOWLING SCORECARD. DO NOT GENERATE RANDOM ROLLS. AN ACTUAL USER INTERFACE IS OPTIONAL** | ||
1. Fork this repository and clone it to your local machine. | ||
2. Open the project in your preferred JavaScript development environment. | ||
3. Use the provided `Scorecard` class to interact with the scorecard. | ||
4. You can add frames and calculate the score using the `addFrame` and `calculateScore` methods, respectively. | ||
5. Feel free to explore and extend the functionality by adding any additional methods you find useful. | ||
|
||
Count and sum the scores of a bowling game for one player (in JavaScript). | ||
## Usage Example | ||
|
||
A bowling game consists of 10 frames in which the player tries to knock down the 10 pins. In every frame the player can roll one or two times. The actual number depends on strikes and spares. The score of a frame is the number of knocked down pins plus bonuses for strikes and spares. After every frame the 10 pins are reset. | ||
Here's an example of how the bowling scorecard can be used: | ||
|
||
Start by looking in detail at the rules and the example of scoring for a complete game given below. | ||
|
||
An example of how your code might be used could be: | ||
|
||
```javaScript | ||
let scorecard = new Scorecard() | ||
scorecard.calculateScore() // returns 0 | ||
scorecard.addFrame(2, 5) | ||
scorecard.addFrame(3, 5) | ||
scorecard.calculateScore() // returns 15 | ||
```javascript | ||
let scorecard = new Scorecard(); | ||
scorecard.calculateScore(); // returns 0 | ||
scorecard.addFrame(2, 5); | ||
scorecard.addFrame(3, 5); | ||
scorecard.calculateScore(); // returns 15 | ||
``` | ||
|
||
But feel free to add other methods if you think they are useful. | ||
|
||
As usual please start by | ||
You can create an instance of the `Scorecard` class, add frames using the `addFrame` method, and calculate the score using the `calculateScore` method. | ||
|
||
* Forking this repo | ||
## Testing | ||
|
||
* Using test-driven development (if you decide to write a user interface, then make sure you have looked at the chapters on mocking). | ||
Test-driven development is encouraged for this project. You can write tests using your preferred testing framework to ensure the correctness of your implementation. However, it is not necessary to include the tests in this repository. | ||
|
||
* Finally submit a pull request before Monday week at 9am with your solution or partial solution. However much or little amount of code you wrote please please please submit a pull request before Monday week at 9am. | ||
## Optional Extras | ||
|
||
___STRONG HINT, IGNORE AT YOUR PERIL:___ Bowling is a deceptively complex game. Careful thought and thorough diagramming — both before and throughout — will save you literal hours of your life. | ||
If you want to challenge yourself further, you can consider the following optional extras: | ||
|
||
### Optional Extras | ||
- Set up Travis CI to automate the testing process. | ||
- Integrate ESLint into your codebase to enforce JavaScript code conventions. | ||
- Create a user interface class that allows running a game from the command line. | ||
|
||
In any order you like: | ||
Feel free to explore these extras in any order you prefer. | ||
|
||
* Set up [Travis CI](https://travis-ci.org) to run your tests. | ||
* Add [ESLint](http://eslint.org/) to your codebase and make your code conform. | ||
* Create a UserInterface class, allowing you to run a game from the command line. | ||
## Bowling Rules and Scoring | ||
|
||
You might even want to start with ESLint early on in your work — to help you | ||
learn Javascript conventions as you go along. | ||
|
||
## Bowling — how does it work? | ||
To better understand the rules and scoring of bowling, please refer to the rules and examples provided below: | ||
|
||
### Strikes | ||
|
||
The player has a strike if he knocks down all 10 pins with the first roll in a frame. The frame ends immediately (since there are no pins left for a second roll). The bonus for that frame is the number of pins knocked down by the next two rolls. That would be the next frame, unless the player rolls another strike. | ||
A strike occurs when the player knocks down all 10 pins with the first roll in a frame. The frame ends immediately, and the bonus for that frame is the number of pins knocked down by the next two rolls. The next frame is considered for the bonus unless the player rolls another strike. | ||
|
||
### Spares | ||
|
||
The player has a spare if the knocks down all 10 pins with the two rolls of a frame. The bonus for that frame is the number of pins knocked down by the next roll (first roll of next frame). | ||
A spare occurs when the player knocks down all 10 pins with the two rolls of a frame. The bonus for that frame is the number of pins knocked down by the next roll (the first roll of the next frame). | ||
|
||
### 10th frame | ||
### 10th Frame | ||
|
||
If the player rolls a strike or spare in the 10th frame they can roll the additional balls for the bonus. But they can never roll more than 3 balls in the 10th frame. The additional rolls only count for the bonus not for the regular frame count. | ||
In the 10th frame, if the player rolls a strike or spare, they can roll additional balls for the bonus. However, the player can never roll more than 3 balls in the 10th frame. The additional rolls only count for the bonus and not for the regular frame count. | ||
|
||
10, 10, 10 in the 10th frame gives 30 points (10 points for the regular first strike and 20 points for the bonus). | ||
1, 9, 10 in the 10th frame gives 20 points (10 points for the regular spare and 10 points for the bonus). | ||
- Example 1: 10, 10, 10 in the 10th frame gives 30 points (10 points for the regular first strike and 20 points for the bonus). | ||
- Example 2: 1, 9, 10 in the 10th frame gives 20 points (10 points for the regular spare and 10 points for the bonus). | ||
|
||
### Gutter Game | ||
|
||
A Gutter Game is when the player never hits a pin (20 zero scores). | ||
A Gutter Game occurs when the player fails to hit any pins in all frames, resulting in 20 zero scores. | ||
|
||
### Perfect Game | ||
|
||
A Perfect Game is when the player rolls 12 strikes (10 regular strikes and 2 strikes for the bonus in the 10th frame). The Perfect Game scores 300 points. | ||
|
||
In the image below you can find some score examples. | ||
|
||
More about ten pin bowling here: http://en.wikipedia.org/wiki/Ten-pin_bowling | ||
|
||
![Ten Pin Score Example](images/example_ten_pin_scoring.png) | ||
|
||
## Code Review | ||
|
||
In code review we'll be hoping to see: | ||
|
||
* All tests passing | ||
* The code is elegant: every class has a clear responsibility, methods are short etc. | ||
A Perfect Game occurs when the player rolls 12 strikes, including 10 regular strikes and 2 strikes for the bonus in the 10th frame. A Perfect Game scores 300 points. | ||
|
||
Reviewers will potentially be using this [code review rubric](docs/review.md). Note that referring to this rubric in advance may make the challenge somewhat easier. You should be the judge of how much challenge you want. | ||
For more information on ten-pin bowling, you can |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,17 @@ | ||
module.exports = { | ||
"env": { | ||
"browser": true, | ||
"commonjs": true, | ||
"es2021": true | ||
}, | ||
"extends": "eslint:recommended", | ||
"overrides": [ | ||
], | ||
"parserOptions": { | ||
"ecmaVersion": "latest" | ||
}, | ||
"rules": { | ||
"semi": ["error", "never"], | ||
"quotes": ["error", "double"] | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,25 @@ | ||
class Frame { | ||
constructor(rolls) { | ||
this.rolls = rolls | ||
this.bonus = 0 | ||
} | ||
|
||
score(){ | ||
let sum = this.rolls.reduce((acc, number) => acc + number) | ||
return sum + this.bonus | ||
} | ||
|
||
addBonus(bonus) { | ||
this.bonus = bonus | ||
} | ||
|
||
isSpare(){ | ||
return this.rolls.reduce((acc, number) => acc + number) === 10 | ||
} | ||
|
||
isStrike(){ | ||
return this.rolls[0] === 10 | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. nice ! terse way to write |
||
} | ||
} | ||
|
||
module.exports = Frame |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,20 @@ | ||
const Scoreboard = require('./score') | ||
|
||
let scorecard = new Scoreboard() | ||
|
||
scorecard.calculateScore() // returns 0 | ||
// scorecard.addFrame(2, 5) | ||
// scorecard.addFrame(3, 5) | ||
// scorecard.addFrame(3, 5) | ||
// scorecard.addFrame(3, 5) | ||
// scorecard.addFrame(3, 5) | ||
// scorecard.addFrame(3, 5) | ||
// scorecard.addFrame(3, 5) | ||
// scorecard.addFrame(3, 5) | ||
// scorecard.addFrame(3, 5) | ||
// scorecard.addFrame(3, 5) | ||
// scorecard.addFrame(3, 5) | ||
scorecard.addFrame(10) | ||
scorecard.addFrame(10) | ||
|
||
console.log(scorecard.calculateScore()) |
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
great use of reduce