Problem Description
You are given an m x n matrix board, representing the current state of a crossword puzzle. The crossword contains lowercase English letters (from solved words), ' ' to represent any empty cells, and '#' to represent any blocked cells. A word can be placed horizontally (left to right or right to left) or vertically (top to bottom or bottom to top) in the board if:
- It does not occupy a cell containing the character '#'.
- The cell each letter is placed in must either be ' ' (empty) or match the letter already on the board.
- There must not be any empty cells ' ' or other lowercase letters directly left or right of the word if the word was placed horizontally.
- There must not be any empty cells ' ' or other lowercase letters directly above or below the word if the word was placed vertically.
Given a string word, return true if word can be placed in board, or false otherwise.
Key Insights
- The board can have empty spaces, blocked cells, and filled letters.
- The word can be placed in four possible orientations: horizontally (left to right and right to left) and vertically (top to bottom and bottom to top).
- We need to ensure that there are no adjacent filled cells or empty spaces in the direction of the word placement.
Space and Time Complexity
Time Complexity: O(m * n) - We may need to check each cell in the board for potential placement. Space Complexity: O(1) - We use only a few variables to keep track of the current position and checks.
Solution
To solve the problem, we will:
- Iterate through every cell in the board.
- For each empty cell, check if a word can be placed horizontally and vertically.
- For each orientation, validate that:
- The cells occupied by the word do not contain blocked cells ('#').
- The surrounding cells do not contain filled letters or empty cells that would invalidate the placement.
- If a valid placement is found, return true; otherwise, return false after checking all cells.