[
    {
        "problem_id": 1243,
        "domain": [
            "Mathematics -> Discrete Mathematics -> Combinatorics"
        ],
        "difficulty": 5.0,
        "problem_text": "An ant starts at the origin of a coordinate plane. Each minute, it either walks one unit to the right or one unit up, but it will never move in the same direction more than twice in the row. In how many different ways can it get to the point $(5,5)$ ?",
        "sample_id": 1,
        "final_answer": "\\boxed{84}",
        "steps": [
            {
                "step_id": 1,
                "edge": "The problem statement establishes the starting position of the ant. This step explicitly records the origin $(0,0)$ as the initial coordinate, which serves as the foundational reference point for all subsequent movement calculations.",
                "direct_dependent_steps": null,
                "node": "The ant starts at the origin $(0,0)$."
            },
            {
                "step_id": 2,
                "edge": "This step directly states the target destination specified in the problem: the point $(5,5)$. This endpoint defines the spatial constraints that determine the required number of directional moves and forms the basis for calculating valid paths.",
                "direct_dependent_steps": null,
                "node": "The ant must reach the point $(5,5)$."
            },
            {
                "step_id": 3,
                "edge": "The problem explicitly restricts the ant's movement options to only two possibilities per minute: one unit upward or one unit to the right. This binary choice of direction is a critical constraint that shapes the entire path enumeration process and justifies the later encoding of moves as binary values.",
                "direct_dependent_steps": null,
                "node": "Each move is either one unit up or one unit to the right."
            },
            {
                "step_id": 4,
                "edge": "To reach the y-coordinate of 5 from the origin (Step 1), the ant must accumulate exactly five upward movements, as each upward move increases the y-value by 1. This follows directly from the coordinate geometry established in Steps 1 and 2, where the vertical displacement requirement dictates the precise count of up moves.",
                "direct_dependent_steps": [
                    1,
                    2
                ],
                "node": "The ant makes exactly 5 up moves."
            },
            {
                "step_id": 5,
                "edge": "Similarly, to achieve the x-coordinate of 5 (Step 2), the ant requires exactly five rightward movements, since each right move increments the x-value by 1. This horizontal displacement requirement is derived solely from the target point specified in Step 2.",
                "direct_dependent_steps": [
                    2
                ],
                "node": "The ant makes exactly 5 right moves."
            },
            {
                "step_id": 6,
                "edge": "The total move count combines the essential vertical and horizontal displacements: five up moves (Step 4) plus five right moves (Step 5) yields exactly ten moves. This summation establishes the fixed length of all valid paths, which is necessary for structuring the sequence analysis in subsequent steps.",
                "direct_dependent_steps": [
                    4,
                    5
                ],
                "node": "Hence the ant makes a total of 10 moves."
            },
            {
                "step_id": 7,
                "edge": "To systematically analyze the path, we represent the sequence of ten moves (Step 6) as an indexed list $a_1$ through $a_{10}$. This encoding provides a formal mathematical structure for examining directional patterns, run lengths, and constraint compliance throughout the solution.",
                "direct_dependent_steps": [
                    6
                ],
                "node": "We encode the sequence of moves as $a_1,a_2,\\dots,a_{10}$."
            },
            {
                "step_id": 8,
                "edge": "Building on the directional definitions (Step 3) and the sequence framework (Step 7), we assign $a_i=0$ to denote an upward move. This binary encoding simplifies the identification of directional runs and aligns with standard combinatorial representation techniques for path analysis.",
                "direct_dependent_steps": [
                    3,
                    7
                ],
                "node": "We define $a_i=0$ if the $i$-th move is up."
            },
            {
                "step_id": 9,
                "edge": "Parallel to Step 8, we define $a_i=1$ for rightward moves using the directional options from Step 3 and the sequence structure in Step 7. This complementary encoding creates a consistent binary system where the entire path can be analyzed through the lens of 0s (up) and 1s (right).",
                "direct_dependent_steps": [
                    3,
                    7
                ],
                "node": "We define $a_i=1$ if the $i$-th move is right."
            },
            {
                "step_id": 10,
                "edge": "Using the upward move encoding from Step 8, we define an 'up run' as a maximal consecutive sequence of 0s. This concept is essential for enforcing the movement constraint, as it isolates uninterrupted upward segments whose lengths must later be verified against the 'no more than two in a row' rule.",
                "direct_dependent_steps": [
                    8
                ],
                "node": "A maximal sequence of consecutive zeros in $a_1,\\dots,a_{10}$ is called an up run."
            },
            {
                "step_id": 11,
                "edge": "Analogous to Step 10, a 'right run' is defined as a maximal consecutive sequence of 1s based on the right-move encoding in Step 9. These runs represent uninterrupted rightward segments and will be subjected to the same length constraint as up runs during validation.",
                "direct_dependent_steps": [
                    9
                ],
                "node": "A maximal sequence of consecutive ones in $a_1,\\dots,a_{10}$ is called a right run."
            },
            {
                "step_id": 12,
                "edge": "Since up runs (Step 10) and right runs (Step 11) are defined as maximal sequences, they must strictly alternate—no two consecutive runs can share the same direction. This alternation property is a fundamental characteristic of run-based path decomposition and ensures directional transitions between every pair of adjacent runs.",
                "direct_dependent_steps": [
                    10,
                    11
                ],
                "node": "Up runs and right runs alternate in the sequence of moves."
            },
            {
                "step_id": 13,
                "edge": "This step restates the core movement constraint from the problem: the ant cannot repeat the same direction three times consecutively. This rule directly governs the permissible lengths of directional runs and serves as the primary restriction that differentiates valid paths from invalid ones.",
                "direct_dependent_steps": null,
                "node": "The ant never moves in the same direction more than twice in a row."
            },
            {
                "step_id": 14,
                "edge": "Given the movement constraint (Step 13) and the definitions of up runs (Step 10) and right runs (Step 11), each run—whether up or right—must have length at most two. This follows because a run of length three would violate the 'no more than two in a row' rule, making such sequences invalid by definition.",
                "direct_dependent_steps": [
                    10,
                    11,
                    13
                ],
                "node": "Therefore each run has length at most two."
            },
            {
                "step_id": 15,
                "edge": "The total upward displacement (five units) must equal the sum of all individual up-run lengths, as established by the definition of up runs in Step 10. This additive property holds because up runs partition the complete sequence of upward moves without overlap or omission.",
                "direct_dependent_steps": [
                    10
                ],
                "node": "The total number of up moves equals the sum of the lengths of the up runs."
            },
            {
                "step_id": 16,
                "edge": "Combining the fixed count of five up moves (Step 4) with the run-length summation principle (Step 15), we conclude that the lengths of all up runs must collectively sum to exactly five. This numerical constraint will later determine valid combinations of run counts and lengths.",
                "direct_dependent_steps": [
                    4,
                    15
                ],
                "node": "The lengths of the up runs sum to 5."
            },
            {
                "step_id": 17,
                "edge": "Mirroring Step 15, the total rightward displacement equals the sum of all right-run lengths, as defined in Step 11. This follows from the partitioning nature of maximal runs, ensuring that every right move is accounted for within exactly one right run.",
                "direct_dependent_steps": [
                    11
                ],
                "node": "The total number of right moves equals the sum of the lengths of the right runs."
            },
            {
                "step_id": 18,
                "edge": "Using the fixed count of five right moves (Step 5) and the run-length summation principle (Step 17), we establish that the lengths of all right runs must sum to precisely five. This constraint parallels Step 16 and will be used symmetrically in the solution.",
                "direct_dependent_steps": [
                    5,
                    17
                ],
                "node": "The lengths of the right runs sum to 5."
            },
            {
                "step_id": 19,
                "edge": "To model valid run-length combinations, we define $f(n)$ as the count of sequences of length $n$ using only terms 1 or 2 (Step 14) that sum to 5 (Steps 16 and 18). This function abstracts the problem of distributing five moves across $n$ runs with maximum length two, which is essential for enumerating valid path structures.",
                "direct_dependent_steps": [
                    14,
                    16,
                    18
                ],
                "node": "We define $f(n)$ as the number of sequences of length $n$ with terms in $\\{1,2\\}$ that sum to 5."
            },
            {
                "step_id": 20,
                "edge": "We compute $f(3)$ by enumerating all sequences of three terms (each 1 or 2) summing to 5. The valid combinations are (1,2,2), (2,1,2), and (2,2,1), yielding three sequences. Verification: $1+2+2=5$, and no other permutations exist since three 2s would sum to 6 (exceeding 5).",
                "direct_dependent_steps": [
                    19
                ],
                "node": "We compute $f(3)=3$."
            },
            {
                "step_id": 21,
                "edge": "For $f(4)$, we find sequences of four terms (1 or 2) summing to 5. The only possibility is three 1s and one 2, with the 2 occupying any of the four positions: (2,1,1,1), (1,2,1,1), (1,1,2,1), (1,1,1,2). This gives four sequences, confirmed by $1+1+1+2=5$.",
                "direct_dependent_steps": [
                    19
                ],
                "node": "We compute $f(4)=4$."
            },
            {
                "step_id": 22,
                "edge": "For $f(5)$, the only sequence of five terms (each at least 1) summing to 5 is five 1s: (1,1,1,1,1). Any 2 would require reducing another term below 1 (invalid), so only one sequence exists, verified by $1\\times5=5$.",
                "direct_dependent_steps": [
                    19
                ],
                "node": "We compute $f(5)=1$."
            },
            {
                "step_id": 23,
                "edge": "For $n<3$, the maximum sum with terms $\\leq2$ is $2n<5$ (e.g., $n=2$ gives max sum 4). For $n>5$, the minimum sum with terms $\\geq1$ is $n>5$. Thus, $f(n)=0$ for $n\\notin\\{3,4,5\\}$, as no valid sequences exist outside this range.",
                "direct_dependent_steps": [
                    19
                ],
                "node": "For all other integers $n$, we have $f(n)=0$."
            },
            {
                "step_id": 24,
                "edge": "We introduce $n_U$ to denote the count of up runs, formalizing the concept defined in Step 10. This variable will track how the five up moves are distributed across discrete upward segments in the path.",
                "direct_dependent_steps": [
                    10
                ],
                "node": "Let $n_U$ denote the number of up runs."
            },
            {
                "step_id": 25,
                "edge": "Similarly, $n_R$ represents the number of right runs as defined in Step 11. This variable tracks the segmentation of right moves and will be analyzed in parallel with $n_U$ due to the problem's symmetry.",
                "direct_dependent_steps": [
                    11
                ],
                "node": "Let $n_R$ denote the number of right runs."
            },
            {
                "step_id": 26,
                "edge": "Due to the strict alternation of runs (Step 12), the counts $n_U$ and $n_R$ (Steps 24 and 25) can differ by at most one. For example, a path starting and ending with up has $n_U = n_R + 1$, while a path starting with up and ending with right has $n_U = n_R$.",
                "direct_dependent_steps": [
                    12,
                    24,
                    25
                ],
                "node": "Alternation of runs implies $|n_U - n_R| \\le 1$."
            },
            {
                "step_id": 27,
                "edge": "From Steps 20–23, $f(n)$ is nonzero only for $n \\in \\{3,4,5\\}$, meaning valid run counts for both directions must lie within this set. This restriction arises because fewer than three runs cannot sum to five with maximum length two, and more than five runs would require minimum sum exceeding five.",
                "direct_dependent_steps": [
                    20,
                    21,
                    22,
                    23
                ],
                "node": "Each of $n_U$ and $n_R$ must lie in $\\{3,4,5\\}$."
            },
            {
                "step_id": 28,
                "edge": "Combining the alternation constraint $|n_U - n_R| \\leq 1$ (Step 26) with the feasible run counts $\\{3,4,5\\}$ (Step 27), we enumerate all valid pairs: $(3,3)$, $(3,4)$, $(4,3)$, $(4,4)$, $(4,5)$, $(5,4)$, $(5,5)$. Each pair satisfies both the alternation rule and the run-count feasibility.",
                "direct_dependent_steps": [
                    26,
                    27
                ],
                "node": "The valid integer pairs $(n_U,n_R)$ satisfying these conditions are $(3,3),(3,4),(4,3),(4,4),(4,5),(5,4),(5,5)$."
            },
            {
                "step_id": 29,
                "edge": "To avoid double-counting symmetric cases (e.g., $(3,4)$ and $(4,3)$), we consider unordered pairs where $n_U \\leq n_R$ or vice versa. This reduces the valid pairs to $(3,3)$, $(3,4)$, $(4,4)$, $(4,5)$, $(5,5)$, recognizing that direction symmetry will be handled later by a multiplicative factor.",
                "direct_dependent_steps": [
                    28
                ],
                "node": "By counting unordered run-count pairs we consider only $(3,3),(3,4),(4,4),(4,5),(5,5)$."
            },
            {
                "step_id": 30,
                "edge": "For a fixed number of up runs $n_U$ (Step 24), the number of ways to distribute five up moves into runs of length 1 or 2 is given by $f(n_U)$ (Step 19). This follows directly from the definition of $f(n)$ as the count of valid run-length sequences summing to five.",
                "direct_dependent_steps": [
                    19,
                    24
                ],
                "node": "For a given $n_U$, there are $f(n_U)$ ways to choose the up-run lengths."
            },
            {
                "step_id": 31,
                "edge": "Analogous to Step 30, for a fixed $n_R$ (Step 25), the count of valid right-run length combinations is $f(n_R)$ (Step 19). This symmetry between up and right directions simplifies the calculation of total path configurations.",
                "direct_dependent_steps": [
                    19,
                    25
                ],
                "node": "For a given $n_R$, there are $f(n_R)$ ways to choose the right-run lengths."
            },
            {
                "step_id": 32,
                "edge": "For each unordered run-count pair (Step 29), the path can begin with either an up run or a right run. This choice doubles the number of configurations for symmetric pairs (e.g., $(3,4)$), as starting direction determines whether $n_U = n_R$ or $|n_U - n_R| = 1$.",
                "direct_dependent_steps": [
                    29
                ],
                "node": "For each unordered pair $\\{n_U,n_R\\}$ there are two choices for whether the sequence begins with an up run or a right run."
            },
            {
                "step_id": 33,
                "edge": "Aggregating all cases from Step 29, we compute $f(n_U) \\times f(n_R)$ for each pair (Steps 30 and 31), sum these products, and apply the starting-direction multiplier of 2 (Step 32). This yields $2\\bigl(f(3)^2 + f(3)f(4) + f(4)^2 + f(4)f(5) + f(5)^2\\bigr)$, which accounts for all valid path structures.",
                "direct_dependent_steps": [
                    29,
                    30,
                    31,
                    32
                ],
                "node": "Hence the total number of valid move sequences is $2\\bigl(f(3)^2+f(3)f(4)+f(4)^2+f(4)f(5)+f(5)^2\\bigr)$."
            },
            {
                "step_id": 34,
                "edge": "We calculate $f(3)^2 = 3 \\times 3 = 9$ using the value from Step 20. Verification: $3^2 = 9$ is a basic arithmetic identity, consistent with the three up-run and three right-run combinations for the $(3,3)$ pair.",
                "direct_dependent_steps": [
                    20
                ],
                "node": "We compute $f(3)^2=9$."
            },
            {
                "step_id": 35,
                "edge": "Computing $f(3)f(4) = 3 \\times 4 = 12$ combines the values from Steps 20 and 21. This product represents the configurations for asymmetric pairs like $(3,4)$, and $3 \\times 4 = 12$ is verified through direct multiplication.",
                "direct_dependent_steps": [
                    20,
                    21
                ],
                "node": "We compute $f(3)f(4)=12$."
            },
            {
                "step_id": 36,
                "edge": "We find $f(4)^2 = 4 \\times 4 = 16$ using Step 21's value. This corresponds to the $(4,4)$ pair, and $4^2 = 16$ is a straightforward arithmetic check confirming the calculation.",
                "direct_dependent_steps": [
                    21
                ],
                "node": "We compute $f(4)^2=16$."
            },
            {
                "step_id": 37,
                "edge": "The product $f(4)f(5) = 4 \\times 1 = 4$ uses values from Steps 21 and 22. This covers pairs like $(4,5)$, and $4 \\times 1 = 4$ is trivially verified by multiplication.",
                "direct_dependent_steps": [
                    21,
                    22
                ],
                "node": "We compute $f(4)f(5)=4$."
            },
            {
                "step_id": 38,
                "edge": "We compute $f(5)^2 = 1 \\times 1 = 1$ based on Step 22. For the $(5,5)$ pair, this single configuration arises from five runs of length 1 in both directions, and $1^2 = 1$ is arithmetically sound.",
                "direct_dependent_steps": [
                    22
                ],
                "node": "We compute $f(5)^2=1$."
            },
            {
                "step_id": 39,
                "edge": "Summing the intermediate results (Steps 34–38): $9 + 12 = 21$, $21 + 16 = 37$, $37 + 4 = 41$, $41 + 1 = 42$. This cumulative addition is verified by sequential arithmetic, ensuring the total within the parentheses equals 42.",
                "direct_dependent_steps": [
                    34,
                    35,
                    36,
                    37,
                    38
                ],
                "node": "We sum $9+12+16+4+1$ to get $42$."
            },
            {
                "step_id": 40,
                "edge": "Applying the factor of 2 from Step 33 to the sum 42 (Step 39) gives $2 \\times 42 = 84$. This multiplication accounts for the two possible starting directions (up or right), and $2 \\times 40 = 80$ plus $2 \\times 2 = 4$ confirms $80 + 4 = 84$.",
                "direct_dependent_steps": [
                    33,
                    39
                ],
                "node": "We multiply $2\\times 42$ to obtain $84$."
            },
            {
                "step_id": 41,
                "edge": "The final count of valid paths is derived from Step 40's calculation, which systematically aggregates all constrained path configurations. This result, 84, satisfies all movement rules and coordinate requirements specified in the problem statement.",
                "direct_dependent_steps": [
                    40
                ],
                "node": "The final answer is \\boxed{84}."
            }
        ]
    }
]
