Skip to content

This project aimed to create an automated Scrabble player designed to identify the highest-scoring moves. It leverages the GADDAG data structure to efficiently determine the best possible word placement for maximum points.

Notifications You must be signed in to change notification settings

khaled-abdrabo/scrabble-solver

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Scrabble Solver Projet

The aim of this project was to program an automatic Scrabble player capable of determining the move with the most points using the GADDAG data structure.

solver

Usage

Clone or download and unzip the archive. Compiling this repository is done using the premake4 command. You must therefore verify that it is installed. For that, you can use apt policy premake4 or dpkg -l premake4. Otherwise, Premake packages are available for most linux distributions.

To compile the program type:

premake4 gmake
make

To launch it type:

./bin/main

Options

To make it easier for you to get started, we made several options that can help you debug and better visualize the results.

To slow down the scrolling of the game

./bin/main --slow [seconds: optional]

Debugging mode

This mode helps you debug the game using a saved instance of the board and a particular hand to visualize the results

To get the best move using a board in text format

./bin/main --suzette-text [board] [hand]

Example :

./bin/main --suzette-text ................................................................................................................B.........P....A.........E....T.........R....E.........L....A.........ESBROUFA.......R........................... EELMSTT

To get the best move using a board saved in a (.txt) file

./bin/main --suzette-file [filename]

Example:

./bin/main --suzette-file ./data/boards/board3.txt

P.S. when launching the solver in the normal mode, all the boards are saved in the folder ./data/boards

Other debugging options

You can use the following options:

Command Description
-case, -c [number] to choose a particular starting CASE using a [number] included between [0, 224]
-vertical, -v to search, the best move, vertically
-horizontal, -h to search, the best move, horizontally

Example:

./bin/main --suzette-file ./data/boards/board3.txt -case 200 -vertical

Need some help?

You can use the help option to visualize all the available options (with their explanation)

./bin/main --help

or

./bin/main --h

Project details

This project was developped by Khaled Abdrabo and Salem Messoud during the 3rd year of our Computer Science bachelor's degree in Claude Bernard University - Lyon 1.

About

This project aimed to create an automated Scrabble player designed to identify the highest-scoring moves. It leverages the GADDAG data structure to efficiently determine the best possible word placement for maximum points.

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 3

  •  
  •  
  •