Skip to content

Latest commit

 

History

History
83 lines (58 loc) · 3.06 KB

README.md

File metadata and controls

83 lines (58 loc) · 3.06 KB

Mini Crossword Generator

Randomly generating a 7x7 in 0.4 seconds

The Mini Crossword is a crossword variant where the boards are much smaller, around 5x5. This project randomly generates unique mini crossword boards.

Generated boards can be customized, pre-filled with letters, and are guaranteed to have no repeated words.

How to run

In the same directory, you may type:

make

and then

./main

The program only uses alphabetical words between lengths 3 and 8. Anything else will be ignored.

It requires two files:

  1. data/wordbank.txt - a list of all the words you'd like to use for generation. I've provided one by default.

  2. data/board.txt - what the board should look like. Blacked-out squares are ., blank squares are _, and letters must be lowercase. Take the following board.txt file:

. . _ _ _
_ _ _ _ _
m a r i o
_ _ _ _ _
_ _ _ _ _
_ _ _ . .

This would correspond to the follwing board:

How it works (general overview)

The project relies on tries to procedurally generate words on the board, and backtracks whenever it hits a rut. The board is generated letter-by-letter using the following process:

  1. Using nodes from the tries, each filled square keeps two sets of possible "next letters": one for the next letter in the across direction and one for the next letter in the down direction.

          s
          e
          e
    c o r *
    

    In this case, the possibilities might be the following:

    Down: SEED, SEEK, SEEM, SEEN, SEEP

    ACROSS: CORD, CORE, CORK, CORN, CORP,

    (Note that if there is no set to choose from because the square is adjacent to a border, then the set would consist of every letter in the alphabet).

  2. The square takes the intersection of these two sets:


    An element is arbitrarily chosen from the resulting set and assigned to the square:

      s
      e
      e
c o r D
  1. The algorithm defers to the next square and waits to hear back. If a board is successfully generated after this point, great. However, if board generation fails, it tries the next letter in the set:
      s
      e
      e
c o r K

and defers again to the next square.

  1. If all letters in the set fail to generate boards, then the function returns false and backtracks to the previous square.

This is just the gist, and there are quite a few things done to optimize generation, which are explained in the source code itself.

Limitations

Once you start asking the algorithm to generate boards in the 7x7 and 8x8 range, it can get very slow. Generating a 7x7 board with a good wordbank can take up to a minute if you're unlucky, and 8x8s can take an hour.