[
    {
        "problem_id": 1799,
        "domain": [
            "Mathematics -> Algebra -> Prealgebra -> Simple Equations",
            "Mathematics -> Discrete Mathematics -> Combinatorics"
        ],
        "difficulty": 2.0,
        "problem_text": "In the $5 \\times 5$ grid shown, 15 cells contain X's and 10 cells are empty. What is the smallest number of X's that must be moved so that each row and each column contains exactly three X's?",
        "sample_id": 1,
        "final_answer": "The final answer is \\boxed{2}.",
        "steps": [
            {
                "step_id": 1,
                "edge": "The problem explicitly states a $5 \\times 5$ grid configuration, which establishes the fundamental structure for analyzing rows and columns. This dimension is critical for determining target counts per row and column later in the solution.",
                "direct_dependent_steps": null,
                "node": "The grid is $5\\times5$."
            },
            {
                "step_id": 2,
                "edge": "The problem specifies 15 X's are present in the grid, a key input for calculating required distributions. This total count directly informs the target number of X's per row and column when combined with the grid dimensions from Step 1.",
                "direct_dependent_steps": null,
                "node": "The grid contains $15$ X's."
            },
            {
                "step_id": 3,
                "edge": "Using the grid size from Step 1 (5 rows) and total X's from Step 2 (15), we compute the target per row as $15 \\div 5 = 3$ X's. This uniform distribution is necessary to satisfy the problem's requirement that each row contains exactly three X's, derived from basic division of total elements across equal partitions.",
                "direct_dependent_steps": [
                    1,
                    2
                ],
                "node": "Each row must contain $3$ X's."
            },
            {
                "step_id": 4,
                "edge": "Similarly, applying the grid size from Step 1 (5 columns) and total X's from Step 2 (15), the target per column is $15 \\div 5 = 3$ X's. This calculation follows the same distribution principle as Step 3 but for columns, ensuring mathematical consistency across both dimensions.",
                "direct_dependent_steps": [
                    1,
                    2
                ],
                "node": "Each column must contain $3$ X's."
            },
            {
                "step_id": 5,
                "edge": "The initial grid configuration (implied by Step 1's context) specifies that Column 1 contains 4 X's. This observation is foundational for identifying deviations from the target established in Step 4.",
                "direct_dependent_steps": [
                    1
                ],
                "node": "Column 1 contains $4$ X's."
            },
            {
                "step_id": 6,
                "edge": "Like Column 1 in Step 5, the grid setup (Step 1 context) shows Column 2 also contains 4 X's. This parallel excess in adjacent columns suggests a localized concentration of X's requiring adjustment.",
                "direct_dependent_steps": [
                    1
                ],
                "node": "Column 2 contains $4$ X's."
            },
            {
                "step_id": 7,
                "edge": "Step 4 requires 3 X's per column, while Step 5 shows Column 1 has 4 X's. The excess is calculated as $4 - 3 = 1$ X, indicating Column 1 exceeds the target by one unit. This quantifies the immediate adjustment needed for this column.",
                "direct_dependent_steps": [
                    4,
                    5
                ],
                "node": "Column 1 has an excess of $1$ X relative to the target."
            },
            {
                "step_id": 8,
                "edge": "Following the same logic as Step 7, Step 4's target of 3 X's per column and Step 6's observation of 4 X's in Column 2 yield an excess of $4 - 3 = 1$ X. This confirms a symmetric excess pattern between the first two columns.",
                "direct_dependent_steps": [
                    4,
                    6
                ],
                "node": "Column 2 has an excess of $1$ X relative to the target."
            },
            {
                "step_id": 9,
                "edge": "Summing the excesses identified in Step 7 (1 X for Column 1) and Step 8 (1 X for Column 2) gives a total column excess of $1 + 1 = 2$ X's. This aggregation is essential for determining the minimum moves required, as excesses across multiple columns compound the adjustment burden.",
                "direct_dependent_steps": [
                    7,
                    8
                ],
                "node": "The total column excess is $2$ X's."
            },
            {
                "step_id": 10,
                "edge": "When moving an X, it is relocated from one cell to another: this reduces the source column's count by 1 and increases the destination column's count by 1. For columns exceeding the target (excess columns), moving an X out reduces their excess by 1, but the destination column (if below target) does not contribute to excess. Thus, each move can decrease the total column excess (sum of all column excesses) by at most 1, as verified by considering the net effect on the excess metric.",
                "direct_dependent_steps": null,
                "node": "Each moved X can reduce the total column excess by at most $1$."
            },
            {
                "step_id": 11,
                "edge": "Given the total column excess of 2 X's from Step 9, and recognizing that each move reduces excess by at most 1 (Step 10), at least $2 \\div 1 = 2$ moves are necessary to eliminate all column excesses. This establishes a lower bound for the solution, as fractional moves are impossible and excess must be fully resolved.",
                "direct_dependent_steps": [
                    9,
                    10
                ],
                "node": "Therefore at least $2$ X's must be moved to satisfy the column requirements."
            },
            {
                "step_id": 12,
                "edge": "The grid configuration specifies that Row 1 contains 4 X's, analogous to the column observations in Steps 5 and 6. This row-level excess must be addressed alongside column constraints.",
                "direct_dependent_steps": null,
                "node": "Row 1 contains $4$ X's."
            },
            {
                "step_id": 13,
                "edge": "Similarly, Row 2 is observed to contain 4 X's, mirroring the pattern in Step 12. This symmetry between rows and columns highlights a coordinated adjustment strategy.",
                "direct_dependent_steps": null,
                "node": "Row 2 contains $4$ X's."
            },
            {
                "step_id": 14,
                "edge": "Step 3 requires 3 X's per row, and Step 12 shows Row 1 has 4 X's. The excess is $4 - 3 = 1$ X, directly quantifying the overcount that must be corrected for this row to meet the target.",
                "direct_dependent_steps": [
                    3,
                    12
                ],
                "node": "Row 1 has an excess of $1$ X relative to the target."
            },
            {
                "step_id": 15,
                "edge": "Applying the same calculation as Step 14, Step 3's target of 3 X's per row and Step 13's observation of 4 X's in Row 2 yield an excess of $4 - 3 = 1$ X. This confirms Row 2 also requires reduction by one X.",
                "direct_dependent_steps": [
                    3,
                    13
                ],
                "node": "Row 2 has an excess of $1$ X relative to the target."
            },
            {
                "step_id": 16,
                "edge": "The problem's specific grid layout includes an X at cell (1,1), identified as a candidate for relocation. This cell's position—intersecting Row 1 and Column 1—makes it strategically relevant for addressing dual excesses.",
                "direct_dependent_steps": null,
                "node": "Cell $(1,1)$ contains an X."
            },
            {
                "step_id": 17,
                "edge": "Similarly, cell (2,2) contains an X in the initial configuration. Its location at the intersection of Row 2 and Column 2 positions it to resolve excesses in both dimensions, mirroring the role of cell (1,1).",
                "direct_dependent_steps": null,
                "node": "Cell $(2,2)$ contains an X."
            },
            {
                "step_id": 18,
                "edge": "Removing the X from cell (1,1) (Step 16) decreases Row 1's count by exactly 1, as each cell contributes one unit to its row total. This action directly targets the 1-X excess identified in Step 14.",
                "direct_dependent_steps": [
                    16
                ],
                "node": "Moving the X from cell $(1,1)$ reduces row 1's count by $1$."
            },
            {
                "step_id": 19,
                "edge": "The same relocation from cell (1,1) (Step 16) reduces Column 1's count by 1, since each cell contributes one unit to its column total. This addresses the 1-X excess in Column 1 noted in Step 7.",
                "direct_dependent_steps": [
                    16
                ],
                "node": "Moving the X from cell $(1,1)$ reduces column 1's count by $1$."
            },
            {
                "step_id": 20,
                "edge": "Moving the X from cell (2,2) (Step 17) decreases Row 2's count by 1, directly correcting the 1-X excess in Row 2 established in Step 15 through the same per-cell contribution logic.",
                "direct_dependent_steps": [
                    17
                ],
                "node": "Moving the X from cell $(2,2)$ reduces row 2's count by $1$."
            },
            {
                "step_id": 21,
                "edge": "Relocating the X from cell (2,2) (Step 17) similarly reduces Column 2's count by 1, targeting the 1-X excess in Column 2 from Step 8 via the fundamental property that each cell affects its column count.",
                "direct_dependent_steps": [
                    17
                ],
                "node": "Moving the X from cell $(2,2)$ reduces column 2's count by $1$."
            },
            {
                "step_id": 22,
                "edge": "Step 14 identifies a 1-X excess in Row 1, and Step 18 confirms removing one X reduces its count by 1. Thus, $4 - 1 = 3$ X's remain, achieving the exact target of 3 X's per row specified in Step 3.",
                "direct_dependent_steps": [
                    14,
                    18
                ],
                "node": "After removing the X from cell $(1,1)$, row 1 contains exactly $3$ X's."
            },
            {
                "step_id": 23,
                "edge": "Following the same progression as Step 22, Step 15's 1-X excess in Row 2 combined with Step 20's reduction yields $4 - 1 = 3$ X's, satisfying Step 3's row target for Row 2.",
                "direct_dependent_steps": [
                    15,
                    20
                ],
                "node": "After removing the X from cell $(2,2)$, row 2 contains exactly $3$ X's."
            },
            {
                "step_id": 24,
                "edge": "Step 7 quantifies Column 1's excess as 1 X, and Step 19 shows moving the X from (1,1) reduces its count by 1. This results in $4 - 1 = 3$ X's, meeting Step 4's column target of exactly 3 X's.",
                "direct_dependent_steps": [
                    7,
                    19
                ],
                "node": "After removing the X from cell $(1,1)$, column 1 contains exactly $3$ X's."
            },
            {
                "step_id": 25,
                "edge": "Analogous to Step 24, Step 8's 1-X excess in Column 2 and Step 21's reduction produce $4 - 1 = 3$ X's, fulfilling Step 4's requirement for Column 2.",
                "direct_dependent_steps": [
                    8,
                    21
                ],
                "node": "After removing the X from cell $(2,2)$, column 2 contains exactly $3$ X's."
            },
            {
                "step_id": 26,
                "edge": "The initial grid configuration reveals Column 5 contains only 1 X, contrasting with the excesses in earlier columns. This deficit must be resolved alongside the excess corrections.",
                "direct_dependent_steps": null,
                "node": "Column 5 contains $1$ X."
            },
            {
                "step_id": 27,
                "edge": "Step 4 requires 3 X's per column, and Step 26 shows Column 5 has 1 X. The deficit is $3 - 1 = 2$ X's, indicating Column 5 needs two additional X's to reach the target.",
                "direct_dependent_steps": [
                    4,
                    26
                ],
                "node": "Column 5 has a deficit of $2$ X's relative to the target."
            },
            {
                "step_id": 28,
                "edge": "The grid contains exactly two rows with only 2 X's each, implying a deficit of 1 X per row relative to Step 3's target of 3. These rows serve as destinations for relocated X's to resolve deficits.",
                "direct_dependent_steps": null,
                "node": "There are exactly two rows containing only $2$ X's."
            },
            {
                "step_id": 29,
                "edge": "Step 28 identifies two rows with 2 X's (deficit rows). Placing the X moved from cell (1,1) (Step 16) into an empty cell in Column 5 of one such row increases that row's count by 1, converting $2 + 1 = 3$ X's to meet Step 3's target. This leverages the moved X to address both row and column deficits simultaneously.",
                "direct_dependent_steps": [
                    16,
                    28
                ],
                "node": "Placing the X moved from cell $(1,1)$ into an empty cell in column 5 of a row with $2$ X's increases that row's count by $1$."
            },
            {
                "step_id": 30,
                "edge": "Inserting the X from cell (1,1) (Step 16) into Column 5 increases Column 5's count by 1, as each added cell contributes one unit to its column total. This action directly contributes to resolving Column 5's deficit identified in Step 27.",
                "direct_dependent_steps": [
                    16
                ],
                "node": "Placing the X moved from cell $(1,1)$ into an empty cell in column 5 of a row with $2$ X's increases column 5's count by $1$."
            },
            {
                "step_id": 31,
                "edge": "Step 28 specifies two deficit rows. Placing the X from cell (2,2) (Step 17) into an empty cell in Column 5 of the second deficit row increases its count by 1, achieving $2 + 1 = 3$ X's and satisfying Step 3's row requirement for that row.",
                "direct_dependent_steps": [
                    17,
                    28
                ],
                "node": "Placing the X moved from cell $(2,2)$ into an empty cell in column 5 of the other row with $2$ X's increases that row's count by $1$."
            },
            {
                "step_id": 32,
                "edge": "Adding the X from cell (2,2) (Step 17) to Column 5 further increases Column 5's count by 1, continuing the process of resolving the column's deficit through incremental additions.",
                "direct_dependent_steps": [
                    17
                ],
                "node": "Placing the X moved from cell $(2,2)$ into an empty cell in column 5 of the other row with $2$ X's increases column 5's count by $1$."
            },
            {
                "step_id": 33,
                "edge": "Step 27 establishes Column 5's deficit of 2 X's (requiring 2 additions to reach 3). Steps 30 and 32 each add 1 X to Column 5, so the final count is $1 + 1 + 1 = 3$ (original 1 plus two additions), achieving Step 4's target. This arithmetic verification confirms the deficit is fully resolved.",
                "direct_dependent_steps": [
                    27,
                    30,
                    32
                ],
                "node": "After these placements, column 5 contains exactly $3$ X's."
            },
            {
                "step_id": 34,
                "edge": "Step 28 identifies one deficit row starting with 2 X's. Step 29 adds 1 X to this row, resulting in $2 + 1 = 3$ X's. This satisfies Step 3's requirement for exactly three X's in the row, as the addition precisely corrects the deficit.",
                "direct_dependent_steps": [
                    28,
                    29
                ],
                "node": "After these placements, the first of the two previously deficient rows contains exactly $3$ X's."
            },
            {
                "step_id": 35,
                "edge": "Similarly, Step 28's second deficit row begins with 2 X's. Step 31 adds 1 X, yielding $2 + 1 = 3$ X's and meeting Step 3's target for this row through identical deficit-correction logic.",
                "direct_dependent_steps": [
                    28,
                    31
                ],
                "node": "After these placements, the second of the two previously deficient rows contains exactly $3$ X's."
            },
            {
                "step_id": 36,
                "edge": "Steps 22–23 confirm Rows 1–2 now have exactly 3 X's each, while Steps 34–35 fix the two deficit rows. Steps 24–25 resolve Columns 1–2, and Step 33 fixes Column 5. Since all rows (via Steps 22, 23, 34, 35) and columns (via Steps 24, 25, 33) satisfy the 3-X requirement, the grid configuration meets all problem constraints after these adjustments.",
                "direct_dependent_steps": [
                    22,
                    23,
                    24,
                    25,
                    33,
                    34,
                    35
                ],
                "node": "All rows and columns now each contain exactly $3$ X's."
            },
            {
                "step_id": 37,
                "edge": "Steps 18 and 20 describe relocating two X's (from cells (1,1) and (2,2)), confirming exactly two moves were executed. This count is derived directly from the relocation actions performed in those steps.",
                "direct_dependent_steps": [
                    18,
                    20
                ],
                "node": "Exactly $2$ X's were moved."
            },
            {
                "step_id": 38,
                "edge": "Step 11 proves at least 2 moves are necessary to resolve column excesses, while Steps 36–37 demonstrate that exactly 2 moves suffice to satisfy all row and column constraints. Combining this lower bound with the constructive feasibility proof establishes 2 as the minimal number of moves required.",
                "direct_dependent_steps": [
                    11,
                    36,
                    37
                ],
                "node": "The final answer is \\boxed{2}."
            }
        ]
    }
]
