Skip to content

Ada-C6/js-scrabble

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

16 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Scrabble with JavaScript!

We are going to rebuild our Scrabble project using our knew knowledge of JavaScript.

Project Expectations

From the project root, you should be able to execute your code with node scrabble.js. Each function you create should be a part of the Scrabble function (acting as a class).

Baseline Requirements

Review the requirements and come up with a "plan of action" for how you want to approach this problem.

The baseline repository contains an empty node project which contains the starter structure to get you started.

Score chart

Letter Value
A, E, I, O, U, L, N, R, S, T 1
D, G 2
B, C, M, P 3
F, H, V, W, Y 4
K 5
J, X 8
Q, Z 10

Wave 1

Primary Requirements

Create the following functions within the Scrabble module.

  • score(word): returns the total score value for the given word. The word is input as a string (case insensitive). The chart below shows the point value for a given letter.
  • highestScoreFrom(arrayOfWords): returns the word in the array with the highest score.
    • Note that it’s better to use fewer tiles, so if the top score is tied between multiple words, pick the one with the fewest letters.
    • Note that there is a bonus (50 points) for using all seven letters. If the top score is tied between multiple words and one used all seven letters, choose the one with seven letters over the one with fewer tiles.
    • If the there are multiple words that are the same score and same length, pick the first one in supplied list.

You should write your own code using the Scrabble module and test the methods manually to ensure they work properly.

You can run your scrabble.js file by typing:

$  node scrabble.js

Wave 2

Primary Requirements

Create a new Player object. The object should have the following functions:

  • Constructor: Called when you use new Player(name), sets up an instance with the instance variable name assigned
  • name: property which returns the value of the player's name
  • plays: property which returns an Array of the words played by the player
  • play(word): Function which adds the input word to the plays Array
    • Returns false if player has already won
  • totalScore(): Function which sums up and returns the score of the players words
  • hasWon(): Function which returns true if the player has over 100 points, otherwise returns false
  • highestScoringWord(): Function which returns the highest scoring word the user has played
  • highestWordScore(): Function which returns the highestScoringWord score

Optional Enhancements

  • Create a TileBag object that includes functionality that allows us to drawTiles and determine the remaining tiles. Beginning Tile Quantities:
Tiles per letter Letters
1 J, K, Q, X, Z
2 B, C, F, H, M, P, V, W, Y
3 G
4 D, L, S, U
6 N, R, T
8 O
9 A, I
12 E
  • Create a Dictionary object that includes a function for searching a list of words to determine if a given word is a valid word.
  • Create a Board object that has a matrix (array of arrays) of tile places. Check if a word can be played on a given tile place in a certain direction.

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 100.0%