Open Source Your Knowledge, Become a Contributor

Technology knowledge has to be shared and made accessible for free. Join the movement.

Create Content

25x25 Sudoku

Puzzle: 25x25 Sudoku

Author: @yoch

Published Difficulty: Very Hard

Algorithm X Complexity: Should Be Straightforward, but Can Be Challenging (see below)

Strategy

You can successfully finish 25x25 Sudoku just with what you have learned so far, but you might run into timing issues. These large Sudoku grids translate into large Algorithm X matrices that take time to process. Depending on your choice of data structures, you might find that running your code multiple times produces very different run times and there is a reason for that. To understand why that might happen, it is important to identify how many rows make up the matrix for each test case.

Using the basic strategy laid out for 9x9 Sudoku, each known cell only adds one row to the matrix, while each unknown cell adds 25 rows to the matrix. Looking at each test case results in the following:


Unknown Cells (U)Known Cells (K)Rows in the Matrix (25 * U + K)
Test Case 1: Test 12763497249
Test Case 2: Test 23312948569
Test Case 3: Test 33243018401
Test Case 4: Test 43213048329
Test Case 5: Test 53262998449

The Nature of Searching

Seven to eight thousand rows is manageable for Algorithm X, but how those rows are ordered makes a difference. If Algorithm X is trying to cover the cell at (0, 0) and there are 10 options to try, the order in which those 10 options are tried impacts run time. While Algorithm X will always try to optimize the order in which it tries rows and columns, there are times when a handful of options appear to be equally viable. In that case, if the correct option is toward the beginning of the list vs the end of the list makes a difference.

If you would like to see this in action, try the following. For unknown cells, shuffle the list of candidates before you build the actions dictionary. You could use a set since members of a set are unordered or you could use random.shuffle(). Either way, you will experience run times that vary quite a bit.

Where to Go From Here

If patience is not your strong suit, you might be able to pass all test cases and validators just by making sure your matrix is shuffled up a bit each time you run your code. Later in the playground, I will revisit 25x25 Sudoku when I discuss using logic to reduce the problem space. By logically filling in a few more cells of the grid and reducing the candidates for unknown cells, you can shrink the size of the matrix and create a solution that works 100% of the time completely independent of how your matrix gets constructed.

Open Source Your Knowledge: become a Contributor and help others learn. Create New Content