[
    {
        "problem_id": 1356,
        "domain": [
            "Mathematics -> Discrete Mathematics -> Combinatorics"
        ],
        "difficulty": 4.5,
        "problem_text": "A $5 \\times 5$ square grid has the number -3 written in the upper-left square and the number 3 written in the lower-right square. In how many ways can the remaining squares be filled in with integers so that any two adjacent numbers differ by 1, where two squares are adjacent if they share a common edge (but not if they share only a corner)?",
        "sample_id": 1,
        "final_answer": "The final answer is \\boxed{250}",
        "steps": [
            {
                "step_id": 1,
                "edge": "We establish the problem context by noting the grid dimensions as specified in the problem statement. A $5 \\times 5$ grid provides the spatial framework for analyzing adjacency and number placements, with this size directly determining the path counts later in the solution.",
                "direct_dependent_steps": null,
                "node": "We consider a $5\\times5$ square grid."
            },
            {
                "step_id": 2,
                "edge": "The problem explicitly states that the upper-left square contains $-3$, which serves as a fixed starting value. This initial condition anchors the entire grid's numbering system and will be used to compute the index value in subsequent steps.",
                "direct_dependent_steps": null,
                "node": "The upper-left square has the number $-3$."
            },
            {
                "step_id": 3,
                "edge": "Similarly, the problem specifies that the lower-right square contains $3$, establishing a second fixed endpoint. This constraint will later interact with the index calculation to restrict possible grid configurations.",
                "direct_dependent_steps": null,
                "node": "The lower-right square has the number $3$."
            },
            {
                "step_id": 4,
                "edge": "This step reiterates the problem's adjacency definition: squares sharing an edge (not corners) are adjacent. This precise definition is critical because it determines which squares must satisfy the difference-by-1 condition in Step 5, and it underpins all movement analysis in later steps.",
                "direct_dependent_steps": null,
                "node": "Two squares are adjacent if they share a common edge."
            },
            {
                "step_id": 5,
                "edge": "The problem mandates that adjacent squares (per Step 4) must have values differing by exactly 1. This rule is the core constraint driving the entire solution, as it forces the index behavior explored in Steps 6-18 and ultimately enables the combinatorial path counting approach.",
                "direct_dependent_steps": null,
                "node": "Any two adjacent squares must have numbers differing by $1$."
            },
            {
                "step_id": 6,
                "edge": "We introduce a strategic index definition $i+j-k$ for a square at $(i,j)$ with value $k$. This invariant is constructed specifically to exploit the adjacency constraint: by embedding position and value together, it transforms the difference-by-1 condition into predictable index changes during movement, as will be verified in Steps 7-18.",
                "direct_dependent_steps": null,
                "node": "We define the index of a square in row $i$, column $j$ with number $k$ as $i+j-k$."
            },
            {
                "step_id": 7,
                "edge": "Building on Step 4's adjacency definition, we characterize horizontal movement: moving right from $(i,j)$ lands at $(i,j+1)$. This explicit position mapping is necessary to apply the index definition to adjacent squares and analyze how the index evolves during traversal.",
                "direct_dependent_steps": [
                    4
                ],
                "node": "An adjacent square to the right of a square in row $i$, column $j$ is in row $i$, column $j+1$."
            },
            {
                "step_id": 8,
                "edge": "Combining Step 5's difference-by-1 rule with Step 7's right-move position, we deduce that the new value $k'$ must be $k \\pm 1$. This follows directly from the adjacency constraint: since the squares are adjacent per Step 4, their values must differ by exactly 1, giving two possible values for the right neighbor.",
                "direct_dependent_steps": [
                    5,
                    7
                ],
                "node": "If the number in that right square is $k'$, then $k'=k\\pm1$."
            },
            {
                "step_id": 9,
                "edge": "Applying Step 6's index definition to the right-neighbor position from Step 7, we express its index as $i + (j+1) - k'$. This substitution sets up the algebraic manipulation needed to relate the new index to the original square's index, using the position update from horizontal movement.",
                "direct_dependent_steps": [
                    6,
                    7
                ],
                "node": "Its index equals $i+(j+1)-k'$ by the index definition."
            },
            {
                "step_id": 10,
                "edge": "Substituting $k' = k \\pm 1$ (from Step 8) into Step 9's index expression yields $i + j + 1 - (k \\pm 1)$. This critical substitution links the value change (governed by Step 5) to the index calculation, preparing for simplification to reveal the index transformation pattern.",
                "direct_dependent_steps": [
                    8,
                    9
                ],
                "node": "Substituting $k'=k\\pm1$ gives $i+j+1-(k\\pm1)$."
            },
            {
                "step_id": 11,
                "edge": "Simplifying Step 10's expression $i+j+1-(k\\pm1)$ through distributive property gives $i+j-k + 1 \\mp 1$. This algebraic reduction shows that the index change depends on the sign choice in $k \\pm 1$: if $k' = k+1$ then index becomes $i+j-k$, if $k' = k-1$ then index becomes $i+j-k+2$.",
                "direct_dependent_steps": [
                    10
                ],
                "node": "Simplifying $i+j+1-(k\\pm1)$ yields $i+j-k+1\\mp1$."
            },
            {
                "step_id": 12,
                "edge": "Using Step 6's definition of the original index $r = i+j-k$ and Step 11's simplified expression, we conclude the right neighbor's index is either $r$ (if $k' = k+1$) or $r+2$ (if $k' = k-1$). This demonstrates that horizontal movement preserves or increases the index by 2, a key invariant for path analysis.",
                "direct_dependent_steps": [
                    6,
                    11
                ],
                "node": "Hence the index of the square to the right equals the original index $r$ or $r+2$."
            },
            {
                "step_id": 13,
                "edge": "Mirroring Step 7 for vertical movement, Step 4's adjacency definition implies moving down from $(i,j)$ lands at $(i+1,j)$. This position update is essential for parallel analysis of downward moves, analogous to rightward moves in Steps 7-12.",
                "direct_dependent_steps": [
                    4
                ],
                "node": "An adjacent square below a square in row $i$, column $j$ is in row $i+1$, column $j$."
            },
            {
                "step_id": 14,
                "edge": "Applying Step 5's difference-by-1 constraint to Step 13's downward move, we determine the new value $k''$ must be $k \\pm 1$. This follows identically to Step 8 but for vertical adjacency, confirming the value rule applies uniformly to all edge-sharing neighbors.",
                "direct_dependent_steps": [
                    5,
                    13
                ],
                "node": "If the number in that below square is $k''$, then $k''=k\\pm1$."
            },
            {
                "step_id": 15,
                "edge": "Substituting Step 13's down-move position into Step 6's index definition gives $(i+1) + j - k''$. This parallels Step 9 for vertical movement, establishing the foundation to compute how downward traversal affects the index.",
                "direct_dependent_steps": [
                    6,
                    13
                ],
                "node": "Its index equals $(i+1)+j-k''$ by the index definition."
            },
            {
                "step_id": 16,
                "edge": "Inserting $k'' = k \\pm 1$ (from Step 14) into Step 15's expression yields $i + 1 + j - (k \\pm 1)$. This substitution, analogous to Step 10, connects the vertical value change to the index calculation for downward movement.",
                "direct_dependent_steps": [
                    14,
                    15
                ],
                "node": "Substituting $k''=k\\pm1$ gives $i+1+j-(k\\pm1)$."
            },
            {
                "step_id": 17,
                "edge": "Simplifying Step 16's expression $i+1+j-(k\\pm1)$ through algebraic distribution gives $i+j-k + 1 \\mp 1$. This matches Step 11's form exactly, showing downward movement affects the index identically to rightward movement: either no change or +2.",
                "direct_dependent_steps": [
                    16
                ],
                "node": "Simplifying $i+1+j-(k\\pm1)$ yields $i+j-k+1\\mp1$."
            },
            {
                "step_id": 18,
                "edge": "Combining Step 6's original index $r = i+j-k$ with Step 17's result, we confirm the down neighbor's index is $r$ or $r+2$. This completes the symmetry: both right and down moves (the only traversal directions toward the lower-right) can only preserve or increase the index by 2.",
                "direct_dependent_steps": [
                    6,
                    17
                ],
                "node": "Hence the index of the square below equals the original index $r$ or $r+2$."
            },
            {
                "step_id": 19,
                "edge": "We adopt standard grid coordinate conventions where the top row is row 1, as implied by the problem's reference to 'upper-left' and 'lower-right' squares. This row numbering is necessary to compute the upper-left square's index in Step 21.",
                "direct_dependent_steps": null,
                "node": "The upper-left square is in row $1$."
            },
            {
                "step_id": 20,
                "edge": "Similarly, we define the leftmost column as column 1 per standard grid conventions. This column numbering, combined with Step 19's row definition, provides the coordinate system for position-based index calculations.",
                "direct_dependent_steps": null,
                "node": "The upper-left square is in column $1$."
            },
            {
                "step_id": 21,
                "edge": "Using Step 2's fixed value $k=-3$, Step 6's index definition, and Steps 19-20's coordinates $(i,j)=(1,1)$, we compute the upper-left index as $1+1-(-3)$. This substitution applies the index formula to the given starting point, establishing a baseline for all paths.",
                "direct_dependent_steps": [
                    2,
                    6,
                    19,
                    20
                ],
                "node": "Its index equals $1+1-(-3)$ by substituting $i=1$, $j=1$, and $k=-3$ into the index definition."
            },
            {
                "step_id": 22,
                "edge": "Evaluating $1+1+3$ from Step 21 gives $5$. Sanity check: $1+1=2$ and $2-(-3)=2+3=5$, which is consistent with integer arithmetic. This numerical result anchors the entire index system at 5 for the starting square.",
                "direct_dependent_steps": [
                    21
                ],
                "node": "Simplifying $1+1+3$ gives $5$."
            },
            {
                "step_id": 23,
                "edge": "From Step 22's arithmetic, we confirm the upper-left index is exactly 5. This fixed starting index will constrain all possible paths through the grid, as subsequent moves can only maintain or increase the index by even increments.",
                "direct_dependent_steps": [
                    22
                ],
                "node": "Hence the index of the upper-left square is $5$."
            },
            {
                "step_id": 24,
                "edge": "Extending Step 19's row convention, the bottom row of a $5 \\times 5$ grid is row 5. This definition is necessary to locate the lower-right square for index calculation.",
                "direct_dependent_steps": null,
                "node": "The lower-right square is in row $5$."
            },
            {
                "step_id": 25,
                "edge": "Extending Step 20's column convention, the rightmost column is column 5. Together with Step 24, this positions the lower-right square at $(5,5)$ for index computation.",
                "direct_dependent_steps": null,
                "node": "The lower-right square is in column $5$."
            },
            {
                "step_id": 26,
                "edge": "Substituting Step 3's fixed value $k=3$, Step 6's index definition, and Steps 24-25's coordinates $(5,5)$, we compute the lower-right index as $5+5-3$. This applies the index formula to the endpoint, providing a critical constraint for valid configurations.",
                "direct_dependent_steps": [
                    3,
                    6,
                    24,
                    25
                ],
                "node": "Its index equals $5+5-3$ by substituting $i=5$, $j=5$, and $k=3$ into the index definition."
            },
            {
                "step_id": 27,
                "edge": "Simplifying $5+5-3$ from Step 26 gives $7$. Sanity check: $5+5=10$ and $10-3=7$, which is correct. This confirms the endpoint index must be 7, contrasting with the start index of 5.",
                "direct_dependent_steps": [
                    26
                ],
                "node": "Simplifying $5+5-3$ gives $7$."
            },
            {
                "step_id": 28,
                "edge": "Step 27's result establishes that the lower-right square has index 7. This fixed endpoint index, combined with Step 23's start index of 5, creates a non-trivial constraint: paths must evolve from index 5 to 7 while respecting movement rules.",
                "direct_dependent_steps": [
                    27
                ],
                "node": "Hence the index of the lower-right square is $7$."
            },
            {
                "step_id": 29,
                "edge": "From Steps 12 and 18, every right or down move changes the index by 0 or +2. Thus, along any path from upper-left to another square using only these moves (which are the only moves toward the lower-right), the index increases by multiples of 2 from the start value. This invariant is fundamental to bounding possible indices.",
                "direct_dependent_steps": [
                    12,
                    18
                ],
                "node": "Along any path from the upper-left square to another square by moves right or down, each step increases the index by $0$ or $2$."
            },
            {
                "step_id": 30,
                "edge": "Starting from Step 23's index 5 and applying Step 29's increment rule (0 or +2 per move), all reachable indices must be odd integers $\\geq 5$ (i.e., 5,7,9,...). This set describes all possible index values in the grid under the movement constraints.",
                "direct_dependent_steps": [
                    23,
                    29
                ],
                "node": "Starting from index $5$, repeated additions of $0$ or $2$ yield only integers in the set $\\{5,7,9,\\dots\\}$."
            },
            {
                "step_id": 31,
                "edge": "Step 28 requires the lower-right index to be 7, and Step 30 shows indices are non-decreasing (since increments are $\\geq 0$). If any square had index $>7$ (e.g., 9), the index could never decrease to reach 7 at the endpoint—violating Step 28. Thus, no square can exceed index 7.",
                "direct_dependent_steps": [
                    28,
                    30
                ],
                "node": "Since the lower-right square has index $7$, no square can have index exceeding $7$."
            },
            {
                "step_id": 32,
                "edge": "Combining Step 30 (indices are odd $\\geq 5$) and Step 31 (no index $>7$), the only feasible indices are 5 and 7. This binary partition simplifies the grid into two distinct regions based solely on index value.",
                "direct_dependent_steps": [
                    30,
                    31
                ],
                "node": "Therefore every square's index belongs to the set $\\{5,7\\}$."
            },
            {
                "step_id": 33,
                "edge": "From Step 32, every square has index 5 or 7, creating two disjoint regions. Since the grid is connected and index changes only at boundaries (per Steps 12/18), these regions must be contiguous and complementary—meaning they share a well-defined boundary.",
                "direct_dependent_steps": [
                    32
                ],
                "node": "Squares of index $5$ and squares of index $7$ occupy two complementary regions of the grid."
            },
            {
                "step_id": 34,
                "edge": "Step 33's complementary regions must be separated by a boundary path along adjacent edges. This follows because when moving between squares of different indices (5 and 7), the index changes by exactly 2 (per Steps 12/18), so the boundary must traverse edges between such squares.",
                "direct_dependent_steps": [
                    33
                ],
                "node": "The boundary between these regions is a path of adjacent edges."
            },
            {
                "step_id": 35,
                "edge": "Step 34's boundary path must use only upward or rightward steps. This directional constraint arises because index increases only when moving right/down (Steps 12/18), so to traverse the boundary between index-5 and index-7 regions, we must move opposite to the index-increasing directions (i.e., up or right).",
                "direct_dependent_steps": [
                    34
                ],
                "node": "This boundary path uses only upward or rightward steps between adjacent squares."
            },
            {
                "step_id": 36,
                "edge": "Extending Step 35's boundary path along the left and bottom borders connects it to the grid corners. Specifically, starting from the lower-left border and ending at the upper-right border creates a continuous path from lower-left to upper-right corner, as required for combinatorial counting.",
                "direct_dependent_steps": [
                    35
                ],
                "node": "Extending this boundary path along the left and bottom borders yields a path from the lower-left corner to the upper-right corner of the grid."
            },
            {
                "step_id": 37,
                "edge": "Conversely, any upward/rightward path from lower-left to upper-right corner (as in Step 36) must separate the grid into two index regions: squares northwest of the path have index 5, and southeast have index 7. This bijection follows because the path enforces the index change rule across its length (Steps 12/18).",
                "direct_dependent_steps": [
                    34,
                    35
                ],
                "node": "Conversely, any upward/rightward path from the lower-left corner to the upper-right corner partitions the grid into two such index regions."
            },
            {
                "step_id": 38,
                "edge": "Steps 33 and 37 establish that each valid boundary path (per Step 37) uniquely partitions the grid into index-5 and index-7 regions. Thus, the path completely determines the index of every square, which is essential for reconstructing the grid values.",
                "direct_dependent_steps": [
                    33,
                    37
                ],
                "node": "Such a partition uniquely determines the index of each square."
            },
            {
                "step_id": 39,
                "edge": "Rearranging Step 6's index definition $r = i+j-k$ gives $k = i+j - r$. Since position $(i,j)$ is known and index $r$ is determined by the partition (Step 38), this formula uniquely specifies the value $k$ for every square.",
                "direct_dependent_steps": [
                    6
                ],
                "node": "An index and position determine the number in a square via $k=i+j-\\text{index}$."
            },
            {
                "step_id": 40,
                "edge": "Combining Step 38 (path determines all indices) and Step 39 (index and position determine value), each boundary path yields exactly one valid grid filling. This bijection transforms the counting problem into enumerating such paths.",
                "direct_dependent_steps": [
                    38,
                    39
                ],
                "node": "Hence each such path yields a unique filling of numbers in the grid."
            },
            {
                "step_id": 41,
                "edge": "Step 36 identifies two extreme paths lying entirely on the grid border: one along the bottom/right edges and one along the top/left edges. These fail because they do not separate the upper-left (index 5) and lower-right (index 7) squares—they leave both squares in the same index region, violating Step 32.",
                "direct_dependent_steps": [
                    36
                ],
                "node": "Two extreme paths that lie entirely along the grid border fail to separate the upper-left and lower-right squares."
            },
            {
                "step_id": 42,
                "edge": "For a $5 \\times 5$ grid (Step 1), a path from lower-left to upper-right corner (Step 36) requires moving 5 units up and 5 units right across the grid's edge network. This totals 10 moves, with exactly 5 upward and 5 rightward steps in some order.",
                "direct_dependent_steps": [
                    1,
                    36
                ],
                "node": "Each path from the lower-left to the upper-right corner consists of $5$ upward and $5$ rightward steps."
            },
            {
                "step_id": 43,
                "edge": "Step 42 specifies 10 moves with 5 upward and 5 rightward choices. The number of distinct paths is the binomial coefficient $\\binom{10}{5} = 252$, calculated as $\\frac{10!}{5!5!} = 252$. Sanity check: $\\binom{10}{5} = 252$ is a standard combinatorial result.",
                "direct_dependent_steps": [
                    42
                ],
                "node": "The number of such paths is $\\binom{10}{5}=252$."
            },
            {
                "step_id": 44,
                "edge": "Step 43 gives 252 total paths, but Step 41 excludes 2 invalid border paths. Step 40 confirms each remaining path yields a unique valid filling, so subtracting gives $252 - 2 = 250$ valid configurations that satisfy all constraints including the fixed corner values.",
                "direct_dependent_steps": [
                    40,
                    41,
                    43
                ],
                "node": "Excluding the two invalid border paths gives $252-2=250$ valid fillings."
            },
            {
                "step_id": 45,
                "edge": "Step 44's count of 250 valid fillings completes the solution. This result satisfies the problem's adjacency constraints and fixed corner values, as verified through the index invariant and path enumeration process.",
                "direct_dependent_steps": [
                    44
                ],
                "node": "The final answer is \\boxed{250}"
            }
        ]
    }
]
