Skip to content
QuizMaker logoQuizMaker
Activity
DSA Course: Interview Patterns and Problem Solving
Module 11: Recursion & Backtracking
Best Time to Buy and Sell Stock: Greedy Pattern
Maximum Subarray: Kadane Pattern
Move Zeroes: Two pointers Pattern
Contains Duplicate: Set Pattern
Valid Anagram: Frequency map Pattern
Longest Substring Without Repeating Characters: Sliding window Pattern
Valid Palindrome: Two pointers Pattern
Longest Palindromic Substring: Expand around center Pattern
Group Anagrams: Hash key Pattern
Binary Search: Classic search Pattern
Search Insert Position: Lower bound Pattern
First Bad Version: Predicate search Pattern
Search in Rotated Sorted Array: Rotated search Pattern
Find Minimum in Rotated Sorted Array: Rotated minimum Pattern
Valid Parentheses: Stack matching Pattern
Min Stack: Auxiliary stack Pattern
Daily Temperatures: Monotonic stack Pattern
Next Greater Element I: Monotonic stack Pattern
Evaluate Reverse Polish Notation: Stack evaluation Pattern
Reverse Linked List: Pointer reversal Pattern
Merge Two Sorted Lists: Dummy node Pattern
Linked List Cycle: Fast and slow pointers Pattern
Middle of the Linked List: Fast and slow pointers Pattern
Remove Nth Node From End: Two pointers Pattern
Binary Tree Traversals: DFS recursion Pattern
Maximum Depth of Binary Tree: Height recursion Pattern
Binary Tree Level Order Traversal: BFS queue Pattern
Validate Binary Search Tree: Range bounds Pattern
Lowest Common Ancestor: Recursive split Pattern
Connected Components: Adjacency DFS Pattern
Number of Islands: Grid DFS Pattern
Flood Fill: Boundary DFS Pattern
Clone Graph: Hash Map DFS Pattern
Course Schedule: Topological Sort Pattern
Union Find Components: Disjoint Set Pattern
Shortest Path in Unweighted Graph: BFS Distance Pattern
Climbing Stairs: Fibonacci DP Pattern
House Robber: Pick or Skip DP Pattern
Coin Change: Minimum Coins DP Pattern
Longest Increasing Subsequence: Binary Search DP Pattern
Longest Common Subsequence: 2D DP Pattern
0/1 Knapsack: Capacity DP Pattern
Longest Consecutive Sequence: Hash Set Pattern
Subarray Sum Equals K: Prefix Sum Hashmap Pattern
First Unique Character: Frequency Map Pattern
Find Duplicates: Frequency Map Pattern
Ransom Note: Character Availability Pattern
Sort Colors: Dutch National Flag Pattern
Next Permutation: Pivot and Suffix Reversal Pattern
Merge Intervals: Sort and Sweep Pattern
Find First and Last Position: Boundary Binary Search Pattern
Search a 2D Matrix: Flattened Binary Search Pattern
Subsets: Pick or Skip Recursion Pattern
Generate Parentheses: Valid State Backtracking Pattern
Combination Sum: Reuse Choice Backtracking Pattern
N-Queens: Constraint Backtracking Pattern
Word Search: Grid Backtracking Pattern
Kth Largest Element: Size-K Min-Heap Pattern
Top K Frequent Elements: Frequency Heap Pattern
Merge K Sorted Lists: Min-Heap Multiway Merge Pattern
Median Finder: Two Heaps Pattern
Task Scheduler: Greedy Max-Heap Pattern
Jump Game: Farthest Reach Greedy Pattern
Gas Station: Greedy Reset Pattern
Non-overlapping Intervals: Earliest End Greedy Pattern
Minimum Arrows to Burst Balloons: Interval End Greedy Pattern
Partition Labels: Last Occurrence Greedy Pattern
Single Number: XOR Cancellation Pattern
Power of Two: n and n-1 Pattern
Number of 1 Bits: Brian Kernighan Pattern
Single Number III: Rightmost Set Bit Pattern
XOR From 1 to N: Modulo Cycle Pattern
Prime Check: Square Root Trial Division Pattern
Sieve of Eratosthenes: Prime Marking Pattern
GCD: Euclidean Remainder Pattern
Binary Exponentiation: Fast Power Pattern
Modular Inverse: Extended Euclid Pattern
Implement Trie: Prefix Tree Pattern
Longest Common Prefix: Single Branch Trie Pattern
LRU Cache: Hash Map Plus Recency List Pattern
Segment Tree: Range Sum Query Pattern
Fenwick Tree: Binary Indexed Prefix Sum Pattern
CONTENTS

Word Search: Grid Backtracking Pattern

Search a word in a grid by walking adjacent cells without reuse.

DSA Course: Interview Patterns and Problem Solving
Module 11: Recursion & Backtracking
dsa
recursion-backtracking
+1
May 29, 2026
22
A

Learning Outcome

After this lesson, you should be able to mark a grid cell as used during one path and restore it for future paths.

Problem Statement

Given a board and a word, return true if the word exists by moving horizontally or vertically through adjacent cells without reusing a cell.

InputOutputWhy
board = [["A","B","C","E"],["S","F","C","S"],["A","D","E","E"]], word = "ABCCED"trueA path A -> B -> C -> C -> E -> D exists using adjacent cells.

Brute Force Approach

Generate paths without checking the next required character early. This explores too many impossible paths.

Optimized Approach

Start DFS from every matching cell. Stop on boundary, mismatch, or reused cell, and restore the cell after exploring.

Exact Pseudocode

exists(row, col, index):
  if index == word.length:
    return true
  if out of bounds or board[row][col] != word[index]:
    return false
  save cell and mark used
  found = search four neighbors for index + 1
  restore cell
  return found

for each cell:
  if exists(cell, 0):
    return true
return false

Reference Code

class Solution:
    def exist(self, board, word):
        rows, cols = len(board), len(board[0])

        def dfs(r, c, i):
            if i == len(word):
                return True
            if r < 0 or c < 0 or r == rows or c == cols or board[r][c] != word[i]:
                return False

            saved = board[r][c]
            board[r][c] = "#"
            found = (
                dfs(r + 1, c, i + 1) or
                dfs(r - 1, c, i + 1) or
                dfs(r, c + 1, i + 1) or
                dfs(r, c - 1, i + 1)
            )
            board[r][c] = saved
            return found

        for r in range(rows):
            for c in range(cols):
                if dfs(r, c, 0):
                    return True
        return False

Sample Dry Run

StepStateResult
Start Aboard[0][0] matches word[0]Mark A used
Move to BRight neighbor matches word[1]Continue path
Continue C,C,E,DEach step matches next characterindex reaches word length
ReturnBase case trueWord exists

Complexity

MeasureValueReason
Time

O(rows * cols

  • 4^wordLength)
Each cell can start a DFS and each step can branch up to four ways.
SpaceO(wordLength)The recursion depth is at most the word length.

Edge Cases

  • The same cell cannot be reused in one path.
  • Only horizontal and vertical moves are allowed.
  • Restore the cell after each path attempt.

Interview Checklist

  • Check boundary and character mismatch before marking.
  • Mark the current cell as used for this path.
  • Restore the cell before returning.

FAQs

Why restore the cell?

The same cell may be needed in a different path starting elsewhere.

Why mark in-place?

It avoids an extra visited matrix while still preventing reuse in the current path.

What is the core pattern?

Grid backtracking with temporary marking.

Share this article

Share on TwitterShare on LinkedInShare on FacebookShare on WhatsAppShare on Email

Test your knowledge

Take a quick quiz based on this chapter.

hardDSA Course
Word Search - Grid Backtracking Pattern Practice Quiz
5 questions8 min

0 comments

Please login to comment.
No comments yet.
Lesson 5 of 5 in Module 11: Recursion & Backtracking
Previous in Module 11: Recursion & Backtracking
N-Queens: Constraint Backtracking Pattern
Next section: Module 12: Heap & Priority Queue
Kth Largest Element: Size-K Min-Heap Pattern
Module 12: Heap & Priority Queue
Back to DSA Course: Interview Patterns and Problem Solving
Back to moduleCategories