Skip to content

This is my solution of the CS50 speller problem set, using Python, Including, memory allocation and the use of a hash table to manage the size of the data set.

License

Notifications You must be signed in to change notification settings

reyvillenajr/speller-py

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

6 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

speller-py

NOTE: Copying and using this data for your submission will breach CS50's academic honesty policy (https://cs50.harvard.edu/x/2020/honesty/). Make sure you learn the material and provide the solution yourself. It's worth it!

This is my solution for the CS50 speller problem set, using Python. https://cs50.harvard.edu/x/2020/psets/5/speller/ This problem set required implementing a program that spell-checks a file (from a list of words, i.e., the dictionaries provided by CS50).

This was produced as a part of CS50 - Introduction to Computer Science. Uploading my solution to Github is considered reasonable regarding the academic honesty policy. (https://www.reddit.com/r/cs50/comments/63235w/is_this_reasonable/)

This problem required the implementation of the following functions (all within dictionary.py);

load. hash. size. check. unload.

To enhance the speed at which words in a provided text could be spell-checked against the dictionaries;

  1. The dictionaries were opened in the function load and added to a character array.
  2. The character array consisted of linked lists, so each word was loaded into the linked list and then hashed through using the hash function, which provided a hash value.
  3. Size returns the number of nodes/words added by increasing them at each iteration of the while loop contained within the load function.
  4. The load function checks each node against each word in the hash table with the corresponding index to return true if it is present.
  5. Unload frees all of the data contained within the hash table by iterating through the hash table.

About

This is my solution of the CS50 speller problem set, using Python, Including, memory allocation and the use of a hash table to manage the size of the data set.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages