[
    {
        "problem_id": 1839,
        "domain": [
            "Mathematics -> Discrete Mathematics -> Combinatorics"
        ],
        "difficulty": 6.0,
        "problem_text": "Each cell of an $m\\times n$ board is filled with some nonnegative integer. Two numbers in the filling are said to be adjacent if their cells share a common side. (Note that two numbers in cells that share only a corner are not adjacent). The filling is called a garden if it satisfies the following two conditions:\n(i) The difference between any two adjacent numbers is either $0$ or $1$ .\n(ii) If a number is less than or equal to all of its adjacent numbers, then it is equal to $0$ .\nDetermine the number of distinct gardens in terms of $m$ and $n$ .",
        "sample_id": 1,
        "final_answer": "$\\boxed{2^{mn}-1}$",
        "steps": [
            {
                "step_id": 1,
                "edge": "We establish the foundational context by declaring $m$ and $n$ as positive integers, which is inherent to the problem's definition of an $m \\times n$ board. This step sets the domain for all subsequent reasoning without requiring prior steps, as it directly reflects the problem's structural parameters.",
                "direct_dependent_steps": null,
                "node": "Let $m$ and $n$ be positive integers."
            },
            {
                "step_id": 2,
                "edge": "Building on Step 1's definition of $m$ and $n$, we explicitly consider the $m \\times n$ grid of cells. This formalizes the spatial framework for the problem, where each cell will later hold nonnegative integers. The step is necessary to anchor all combinatorial reasoning to a concrete geometric structure defined by the given dimensions.",
                "direct_dependent_steps": [
                    1
                ],
                "node": "Consider an $m\\times n$ board of cells."
            },
            {
                "step_id": 3,
                "edge": "This step states a core problem constraint: each cell contains a nonnegative integer. As this is directly specified in the problem statement (\"filled with some nonnegative integer\"), it requires no dependency on prior steps. This condition ensures all values are well-defined within the discrete mathematical context of the garden filling.",
                "direct_dependent_steps": null,
                "node": "Each cell is filled with a nonnegative integer."
            },
            {
                "step_id": 4,
                "edge": "We define adjacency strictly as cells sharing a common side, which is a direct restatement of the problem's note (\"two numbers in the filling are adjacent if their cells share a common side\"). This clarifies the neighborhood structure for the grid and is essential for interpreting conditions (i) and (ii), requiring no prior steps as it is a given definition.",
                "direct_dependent_steps": null,
                "node": "Two numbers are adjacent if their cells share a common side."
            },
            {
                "step_id": 5,
                "edge": "This step introduces the key concept of a \"garden\" by restating the problem's central definition: a filling satisfying conditions (i) and (ii). As this is explicitly provided in the problem statement, it stands independently without dependencies. Establishing this terminology early is crucial for organizing the logical progression toward characterizing all valid gardens.",
                "direct_dependent_steps": null,
                "node": "A filling is called a garden if it satisfies conditions (i) and (ii)."
            },
            {
                "step_id": 6,
                "edge": "We explicitly detail condition (i) as given in the problem: adjacent numbers differ by at most 1 (i.e., 0 or 1). This is a direct quote from the problem statement and requires no dependencies. Clarifying this constraint upfront enables precise analysis of value transitions across the grid, which will later support the descent argument in Steps 10–12.",
                "direct_dependent_steps": null,
                "node": "Condition (i) is that the difference between any two adjacent numbers is either $0$ or $1$."
            },
            {
                "step_id": 7,
                "edge": "This step specifies condition (ii) verbatim from the problem: any local minimum (a cell value less than or equal to all adjacent values) must be zero. As a direct problem statement, it needs no dependencies. This condition is pivotal for linking positive values to descent paths toward zeros, which will be leveraged in Step 10 to derive structural properties of gardens.",
                "direct_dependent_steps": null,
                "node": "Condition (ii) is that if a number in a cell is less than or equal to all of its adjacent numbers then that number is $0$."
            },
            {
                "step_id": 8,
                "edge": "Assuming $f$ is a garden filling (as defined in Step 5) initiates the forward direction of the bijection proof. This step depends on Step 5 to ensure $f$ satisfies both garden conditions. We make this assumption to systematically derive necessary properties of gardens, setting the stage for showing that every garden is determined by its zero cells.",
                "direct_dependent_steps": [
                    5
                ],
                "node": "Assume $f$ is a garden filling of the board."
            },
            {
                "step_id": 9,
                "edge": "Focusing on a cell $c$ with $f(c) > 0$ (within the garden $f$ from Step 8) isolates non-zero values for analysis. This step depends on Step 8 to establish the garden context. Examining such cells is strategic: condition (ii) implies they cannot be local minima, which will force the existence of descent paths toward zeros in Step 10.",
                "direct_dependent_steps": [
                    8
                ],
                "node": "Let $c$ be a cell such that $f(c)>0$."
            },
            {
                "step_id": 10,
                "edge": "Applying condition (ii) from Step 7 to the positive-valued cell $c$ in Step 9 shows $c$ cannot be a local minimum, so there must exist an adjacent neighbor $d$ with $f(d) < f(c)$. Specifically, Step 7's requirement that local minima must be zero contradicts $f(c) > 0$ if $c$ were minimal, forcing at least one strictly smaller adjacent value. This descent initiation is critical for constructing paths to zero cells.",
                "direct_dependent_steps": [
                    7,
                    9
                ],
                "node": "Condition (ii) implies that the cell $c$ has an adjacent neighbor $d$ with $f(d)<f(c)$."
            },
            {
                "step_id": 11,
                "edge": "Condition (i) from Step 6 directly implies that adjacent values differ by at most 1, so $|f(c) - f(d)| \\leq 1$ for any adjacent cells $c, d$. This step depends solely on Step 6 and refines the adjacency constraint: differences are bounded by 1, which will combine with Step 10's strict inequality to force exact unit decreases in Step 12.",
                "direct_dependent_steps": [
                    6
                ],
                "node": "Condition (i) implies that for any two adjacent cells the difference of their values is at most $1$."
            },
            {
                "step_id": 12,
                "edge": "Combining Step 10 (existence of $d$ with $f(d) < f(c)$) and Step 11 ($|f(c) - f(d)| \\leq 1$), we deduce $f(d) = f(c) - 1$ must hold. The strict decrease from Step 10 and the bounded difference from Step 11 eliminate all possibilities except a unit drop. This precise relationship is essential for building deterministic descent sequences in Step 13.",
                "direct_dependent_steps": [
                    10,
                    11
                ],
                "node": "Steps 10 and 11 imply that there exists an adjacent neighbor $d$ of $c$ such that $f(d)=f(c)-1$."
            },
            {
                "step_id": 13,
                "edge": "Iterating the unit descent from Step 12 starting at $c$ generates a finite sequence $c = c_0, c_1, \\dots, c_k$ where each step satisfies $f(c_{i+1}) = f(c_i) - 1$. This depends only on Step 12, which guarantees the next cell in the path. Finiteness is assured because values are nonnegative integers (Step 3), so the sequence must terminate after at most $f(c)$ steps without cycling.",
                "direct_dependent_steps": [
                    12
                ],
                "node": "Starting from $c$ and iterating this adjacent descent produces a finite sequence of cells $c=c_0,c_1,\\dots,c_k$ with $f(c_{i+1})=f(c_i)-1$."
            },
            {
                "step_id": 14,
                "edge": "The sequence from Step 13 terminates at $c_k$ with $f(c_k) = 0$ because Step 3 ensures values are nonnegative integers, and Step 13's descent ($f(c_{i+1}) = f(c_i) - 1$) would otherwise violate nonnegativity if continued beyond zero. Thus, termination at a zero cell is inevitable, forming the endpoint of the descent path.",
                "direct_dependent_steps": [
                    3,
                    13
                ],
                "node": "The sequence terminates at a cell $c_k$ satisfying $f(c_k)=0$."
            },
            {
                "step_id": 15,
                "edge": "From Step 13's sequence ($f(c_i) = f(c) - i$) and Step 14's termination ($f(c_k) = 0$), we solve $0 = f(c) - k$ to find $k = f(c)$. This identifies the path length $k$ as exactly the value at $c$, confirming that the descent depth matches the initial value. This equivalence is foundational for interpreting $f(c)$ as a distance metric.",
                "direct_dependent_steps": [
                    13,
                    14
                ],
                "node": "The length $k$ of this path equals $f(c)$."
            },
            {
                "step_id": 16,
                "edge": "The path length $k$ from Step 13 and Step 14 equals the minimal distance to a zero cell because: (a) the constructed path has length $k$ to a zero cell, and (b) any path to a zero cell requires at least $k$ steps—since adjacent values differ by at most 1 (Step 11), the value $f(c)$ cannot decrease by more than 1 per step, so the minimal path length is $f(c) = k$. Thus, $k$ is the shortest distance to a zero cell.",
                "direct_dependent_steps": [
                    13,
                    14
                ],
                "node": "The length $k$ also equals the distance from $c$ to the nearest zero cell."
            },
            {
                "step_id": 17,
                "edge": "Combining Step 15 ($f(c) = k$) and Step 16 ($k$ = minimal distance to a zero cell), we conclude $f(c)$ must equal the distance from $c$ to the nearest zero cell for every cell $c$. This step synthesizes the descent argument: all garden values are completely determined by the zero-cell locations, which will enable the bijection in Step 19.",
                "direct_dependent_steps": [
                    15,
                    16
                ],
                "node": "Therefore for every cell $c$ in a garden we have $f(c)$ equal to the distance from $c$ to the nearest zero cell."
            },
            {
                "step_id": 18,
                "edge": "Defining $S$ as the set of zero cells ($f(c) = 0$) within the garden $f$ (from Step 8) isolates the critical reference points. This depends on Step 8 to establish the garden context. Identifying $S$ is strategic because Step 17 implies $S$ dictates all other values, positioning $S$ as the core combinatorial object for characterizing gardens.",
                "direct_dependent_steps": [
                    8
                ],
                "node": "Let $S$ be the set of cells $c$ for which $f(c)=0$."
            },
            {
                "step_id": 19,
                "edge": "Step 17 shows $f(c)$ is the distance to the nearest zero cell, and Step 18 defines $S$ as those zero cells. Thus, given $S$, $f$ is uniquely reconstructed by computing distances to $S$. This dependency proves every garden corresponds to exactly one set $S$, establishing the injective direction of the bijection needed for counting.",
                "direct_dependent_steps": [
                    17,
                    18
                ],
                "node": "Step 17 implies that the garden filling $f$ is uniquely determined by the set $S$ of zero cells."
            },
            {
                "step_id": 20,
                "edge": "Conversely, we consider any nonempty subset $S$ of the $m \\times n$ board's cells (Step 2 defines the board). Nonemptiness is required because an empty $S$ would make distances undefined (or infinite), violating the nonnegative integer constraint. This step initiates the reverse direction of the bijection by exploring arbitrary zero-cell configurations.",
                "direct_dependent_steps": [
                    2
                ],
                "node": "Conversely, let $S$ be any nonempty subset of the set of cells."
            },
            {
                "step_id": 21,
                "edge": "For a nonempty $S$ (Step 20), we define $g(c)$ as the minimal path distance from $c$ to any cell in $S$ along adjacent cells (per Step 4's adjacency definition). This constructs a candidate filling from $S$, which will be verified as a garden in subsequent steps. The definition leverages standard grid distance metrics to mirror the structure derived in Step 17.",
                "direct_dependent_steps": [
                    20
                ],
                "node": "Define $g(c)$ for each cell $c$ to be the distance from $c$ to the nearest cell in $S$."
            },
            {
                "step_id": 22,
                "edge": "By Step 21's construction, $g(c)$ is the length of a shortest path in the grid graph, which is always a nonnegative integer (as paths consist of discrete steps). This step depends on Step 21 and confirms $g$ satisfies the problem's requirement that cells hold nonnegative integers, a prerequisite for checking garden conditions.",
                "direct_dependent_steps": [
                    21
                ],
                "node": "By definition $g(c)$ is a nonnegative integer for every cell $c$."
            },
            {
                "step_id": 23,
                "edge": "For adjacent cells $c, d$ (Step 4), Step 21's distance function satisfies $|g(c) - g(d)| \\leq 1$ because: if $p$ is a shortest path from $c$ to $S$, then moving to $d$ gives a path of length $g(c) + 1$ to $S$, so $g(d) \\leq g(c) + 1$; similarly, $g(c) \\leq g(d) + 1$. This enforces condition (i) (difference at most 1), as required for a garden.",
                "direct_dependent_steps": [
                    4,
                    21
                ],
                "node": "If two cells $c$ and $d$ share a side then $|g(c)-g(d)|\\le1$."
            },
            {
                "step_id": 24,
                "edge": "If $g(c) \\leq g(d)$ for all adjacent $d$ (Step 4), Step 21 implies $g(c) = 0$: suppose $g(c) > 0$; then a shortest path from $c$ to $S$ must pass through a neighbor $d$ with $g(d) = g(c) - 1 < g(c)$, contradicting minimality. Thus, $g(c) = 0$, satisfying condition (ii) (local minima are zero).",
                "direct_dependent_steps": [
                    4,
                    21
                ],
                "node": "If a cell $c$ satisfies $g(c)\\le g(d)$ for all adjacent cells $d$ then $g(c)=0$."
            },
            {
                "step_id": 25,
                "edge": "Steps 22, 23, and 24 collectively verify $g$ is a garden: Step 22 ensures nonnegative integers, Step 23 satisfies condition (i) (adjacent differences ≤1), and Step 24 satisfies condition (ii) (local minima are zero). This confirms that any nonempty $S$ (Step 20) produces a valid garden, completing the surjective direction of the bijection.",
                "direct_dependent_steps": [
                    22,
                    23,
                    24
                ],
                "node": "Steps 23 and 24 show that $g$ satisfies conditions (i) and (ii) and hence is a garden."
            },
            {
                "step_id": 26,
                "edge": "Step 19 shows every garden arises from a unique nonempty set $S$ of zero cells, and Step 25 shows every nonempty $S$ yields a unique garden. Thus, the mapping $S \\mapsto g$ is a bijection: distinct $S$ produce distinct gardens (since zero sets differ), and all gardens are covered. This equivalence reduces counting gardens to counting nonempty subsets of cells.",
                "direct_dependent_steps": [
                    19,
                    25
                ],
                "node": "This construction gives a bijection between nonempty subsets $S$ and gardens."
            },
            {
                "step_id": 27,
                "edge": "This step states a fundamental combinatorial fact: an $m \\times n$ board has $mn$ cells, so there are $2^{mn}$ total subsets (including the empty set). As this is background knowledge in set theory, it requires no dependencies and provides the baseline for subset counting.",
                "direct_dependent_steps": null,
                "node": "There are $2^{mn}$ total subsets of the $mn$ cells."
            },
            {
                "step_id": 28,
                "edge": "The empty subset is exactly one subset of the $mn$ cells, which is a trivial consequence of set theory (the empty set is unique). This independent fact is necessary to exclude the invalid case where $S$ is empty (which would not produce a valid garden, as distances would be undefined).",
                "direct_dependent_steps": null,
                "node": "Exactly one of these subsets is empty."
            },
            {
                "step_id": 29,
                "edge": "Subtracting the single empty subset (Step 28) from the total subsets (Step 27) gives $2^{mn} - 1$ nonempty subsets. This arithmetic is straightforward: $2^{mn}$ total subsets minus 1 empty subset. Sanity check: for a $1 \\times 1$ board, $2^1 - 1 = 1$ garden (only the zero cell), which aligns with the problem constraints.",
                "direct_dependent_steps": [
                    27,
                    28
                ],
                "node": "Hence there are $2^{mn}-1$ nonempty subsets of the cells."
            },
            {
                "step_id": 30,
                "edge": "Step 26 establishes a bijection between nonempty subsets $S$ and gardens, and Step 29 counts these subsets as $2^{mn} - 1$. Therefore, the number of distinct gardens equals $2^{mn} - 1$, which is the final answer. This step consolidates the bijection and counting arguments to resolve the problem.",
                "direct_dependent_steps": [
                    26,
                    29
                ],
                "node": "The final answer is $\\boxed{2^{mn}-1}$. "
            }
        ]
    }
]
