[
    {
        "problem_id": 3276,
        "domain": [
            "Mathematics -> Applied Mathematics -> Statistics -> Probability -> Counting Methods -> Combinations",
            "Mathematics -> Discrete Mathematics -> Combinatorics"
        ],
        "difficulty": 4.0,
        "problem_text": "There are two buildings facing each other, each 5 stories high. How many ways can Kevin string ziplines between the buildings so that: (a) each zipline starts and ends in the middle of a floor. (b) ziplines can go up, stay flat, or go down, but can't touch each other (this includes touching at their endpoints). Note that you can't string a zipline between two floors of the same building.",
        "sample_id": 1,
        "final_answer": "The final answer is \\boxed{252}.",
        "steps": [
            {
                "step_id": 1,
                "edge": "We introduce $k$ as a variable to represent the number of ziplines in any valid configuration. Since configurations can have different numbers of ziplines (ranging from 0 to a maximum determined by building height), defining $k$ allows us to systematically decompose the problem by considering how floors are partitioned around $k$ distinct zipline endpoints on each building.",
                "direct_dependent_steps": null,
                "node": "Let $k$ be the number of ziplines in a configuration."
            },
            {
                "step_id": 2,
                "edge": "We define $a_0$ to count the floors strictly below the lowest zipline endpoint on the left building. As floors are discrete and ziplines attach to midpoints, $a_0$ must be a nonnegative integer representing the number of full floors beneath the first connection point. This definition establishes the foundational gap for our partitioning scheme.",
                "direct_dependent_steps": null,
                "node": "Define nonnegative integer $a_0$ as the number of floors on the left building below the lowest zipline."
            },
            {
                "step_id": 3,
                "edge": "Building on the definition of $k$ (the number of ziplines from Step 1), we define intermediate gaps $a_i$ for $1 \\le i \\le k-1$ to represent floors strictly between consecutive zipline endpoints on the left building. Each $a_i$ must be a nonnegative integer because adjacent ziplines cannot touch (including endpoints), requiring at least zero floors between them. This ensures all vertical spacing constraints are captured for $k$ ziplines.",
                "direct_dependent_steps": [
                    1
                ],
                "node": "For each $1\\le i\\le k-1$, define nonnegative integer $a_i$ as the number of floors on the left building between the $i$th and $(i+1)$th ziplines."
            },
            {
                "step_id": 4,
                "edge": "Extending the left-building gap decomposition, we define $a_k$ to count floors strictly above the highest zipline endpoint. This completes the partitioning of all left-building floors into $k+1$ disjoint intervals ($a_0$ through $a_k$), where the dependency on $k$ (Step 1) guarantees exactly $k+1$ segments corresponding to $k$ ziplines.",
                "direct_dependent_steps": [
                    1
                ],
                "node": "Define nonnegative integer $a_k$ as the number of floors on the left building above the highest zipline."
            },
            {
                "step_id": 5,
                "edge": "Symmetrically to Step 2, we define $b_0$ as the count of floors strictly below the lowest zipline endpoint on the right building. This nonnegative integer ensures consistent modeling of vertical spacing on both buildings, with identical reasoning to $a_0$ but applied to the right structure.",
                "direct_dependent_steps": null,
                "node": "Define nonnegative integer $b_0$ as the number of floors on the right building below the lowest zipline."
            },
            {
                "step_id": 6,
                "edge": "Mirroring Step 3 for the right building, we define $b_i$ ($1 \\le i \\le k-1$) to represent floors between consecutive zipline endpoints. The dependency on $k$ (Step 1) is critical here, as the number of intermediate gaps is inherently tied to the number of ziplines, and nonnegativity enforces the non-touching constraint between adjacent ziplines.",
                "direct_dependent_steps": [
                    1
                ],
                "node": "For each $1\\le i\\le k-1$, define nonnegative integer $b_i$ as the number of floors on the right building between the $i$th and $(i+1)$th ziplines."
            },
            {
                "step_id": 7,
                "edge": "Completing the right-building partition, $b_k$ counts floors above the highest zipline endpoint. Together with $b_0$ through $b_{k-1}$, this forms $k+1$ disjoint intervals covering all right-building floors, with the dependency on $k$ (Step 1) ensuring structural consistency with the left-building decomposition.",
                "direct_dependent_steps": [
                    1
                ],
                "node": "Define nonnegative integer $b_k$ as the number of floors on the right building above the highest zipline."
            },
            {
                "step_id": 8,
                "edge": "The definitions in Steps 2, 3, and 4 collectively partition all 5 left-building floors into disjoint intervals ($a_0$ below, $a_1$ to $a_{k-1}$ between, $a_k$ above). Since every floor must belong to exactly one interval and no floors are omitted or double-counted, the sum of these nonnegative integers must equal the total floors, yielding $\\sum_{i=0}^k a_i = 5$ as a direct consequence of the partitioning.",
                "direct_dependent_steps": [
                    2,
                    3,
                    4
                ],
                "node": "Since each building has $5$ floors we have $\\sum_{i=0}^k a_i=5$."
            },
            {
                "step_id": 9,
                "edge": "Applying identical reasoning to the right-building definitions in Steps 5, 6, and 7, the nonnegative integers $b_0$ through $b_k$ partition all 5 right-building floors. Thus, their sum must also equal 5, giving $\\sum_{i=0}^k b_i = 5$. This equation mirrors Step 8 and enforces the building height constraint symmetrically.",
                "direct_dependent_steps": [
                    5,
                    6,
                    7
                ],
                "node": "Since each building has $5$ floors we have $\\sum_{i=0}^k b_i=5$."
            },
            {
                "step_id": 10,
                "edge": "We establish a correspondence between zipline configurations and piecewise linear paths by interpreting the left-building gaps ($a_i$ from Steps 2-4) as horizontal segment lengths and right-building gaps ($b_i$ from Steps 5-7) as vertical segment lengths. Starting from the bottom, each horizontal segment $a_i$ represents moving right across $a_i$ floors on the left, while each vertical segment $b_i$ represents moving up $b_i$ floors on the right—this encoding transforms zipline spacing into a lattice path without crossings.",
                "direct_dependent_steps": [
                    2,
                    3,
                    4,
                    5,
                    6,
                    7
                ],
                "node": "We map each configuration to a piecewise linear path by taking horizontal segments of lengths $a_0,a_1,\\dots,a_k$ and vertical segments of lengths $b_0,b_1,\\dots,b_k$."
            },
            {
                "step_id": 11,
                "edge": "The path construction in Step 10 begins at $(0,0)$ because $a_0$ counts floors below the lowest zipline, meaning no displacement has occurred before the first segment. This origin point anchors all paths consistently, as $a_0 = 0$ would imply the lowest zipline starts at the ground floor midpoint, while $a_0 > 0$ shifts the path rightward proportionally.",
                "direct_dependent_steps": [
                    10
                ],
                "node": "Each such path starts at $(0,0)$."
            },
            {
                "step_id": 12,
                "edge": "Following the path construction of Step 10, the total horizontal displacement equals the sum of all left-building gap lengths ($\\sum a_i$), and the total vertical displacement equals the sum of all right-building gap lengths ($\\sum b_i$). Thus, the path terminates at $(\\sum_{i=0}^k a_i, \\sum_{i=0}^k b_i)$, directly translating the floor partitioning into endpoint coordinates.",
                "direct_dependent_steps": [
                    10
                ],
                "node": "Each such path ends at $(\\sum_{i=0}^k a_i,\\sum_{i=0}^k b_i)$."
            },
            {
                "step_id": 13,
                "edge": "Substituting the floor totals from Steps 8 ($\\sum a_i = 5$) and 9 ($\\sum b_i = 5$) into the endpoint expression from Step 12, we find every valid path must end at $(5,5)$. This fixed endpoint arises because both buildings have exactly 5 floors, constraining the cumulative horizontal and vertical displacements to match the building heights.",
                "direct_dependent_steps": [
                    8,
                    9,
                    12
                ],
                "node": "By Steps 8 and 9 the endpoint of each path is $(5,5)$."
            },
            {
                "step_id": 14,
                "edge": "The path construction in Step 10 is reversible: given any such lattice path, the horizontal segments directly yield the $a_i$ sequence (left-building gaps) and vertical segments yield $b_i$ (right-building gaps), which uniquely determine zipline positions. Since no two configurations produce identical paths and all paths correspond to valid non-touching configurations, the mapping is bijective—ensuring exact correspondence between zipline arrangements and paths.",
                "direct_dependent_steps": [
                    10
                ],
                "node": "The mapping is bijective because given such a path one recovers the sequences $(a_i)$ and $(b_i)$ uniquely."
            },
            {
                "step_id": 15,
                "edge": "Combining the bijective mapping (Step 14), the fixed start $(0,0)$ from Step 11, and the fixed endpoint $(5,5)$ from Step 13, we conclude that counting zipline configurations is equivalent to counting monotonic lattice paths from $(0,0)$ to $(5,5)$ using only right and up unit steps. Each right move corresponds to traversing a floor gap on the left building, and each up move corresponds to a gap on the right.",
                "direct_dependent_steps": [
                    11,
                    13,
                    14
                ],
                "node": "Thus the number of zipline configurations equals the number of lattice paths from $(0,0)$ to $(5,5)$ using right and up segments."
            },
            {
                "step_id": 16,
                "edge": "A lattice path from $(0,0)$ to $(5,5)$ requires exactly 5 right moves (total horizontal displacement 5) and 5 up moves (total vertical displacement 5), resulting in a sequence of 10 unit steps. Step 15 confirms this path representation corresponds to our problem, so we model configurations as ordered sequences of these 10 moves where direction encodes building-side progression.",
                "direct_dependent_steps": [
                    15
                ],
                "node": "Such a lattice path can be encoded by a sequence of $10$ unit steps consisting of rights and ups."
            },
            {
                "step_id": 17,
                "edge": "To reach $(5,5)$ as established in Step 13, the path must accumulate exactly 5 units in both directions. Step 16 describes the path as 10 unit steps, so precisely 5 must be rightward (to achieve $x=5$) and 5 upward (to achieve $y=5$). Any deviation—such as 6 rights—would overshoot the endpoint, violating the building height constraints from Steps 8 and 9.",
                "direct_dependent_steps": [
                    13,
                    16
                ],
                "node": "To reach $(5,5)$ the sequence must contain exactly $5$ rights and $5$ ups."
            },
            {
                "step_id": 18,
                "edge": "With exactly 5 right moves required in a 10-step sequence (Step 17), the number of distinct paths equals the number of ways to choose positions for these right moves. This is given by the binomial coefficient $\\binom{10}{5}$, which counts combinations of 10 steps taken 5 at a time for rightward movement, with the remaining steps implicitly being upward.",
                "direct_dependent_steps": [
                    17
                ],
                "node": "The number of ways to choose which $5$ of the $10$ steps are rights is $\\binom{10}{5}$."
            },
            {
                "step_id": 19,
                "edge": "Evaluating the binomial coefficient: $\\binom{10}{5} = \\frac{10!}{5!5!} = \\frac{10 \\times 9 \\times 8 \\times 7 \\times 6}{5 \\times 4 \\times 3 \\times 2 \\times 1} = 252$. Sanity check: $5 \\times 4 \\times 3 \\times 2 \\times 1 = 120$ and $10 \\times 9 \\times 8 \\times 7 \\times 6 = 30240$, so $30240 / 120 = 252$, confirming the arithmetic.",
                "direct_dependent_steps": [
                    18
                ],
                "node": "We compute $\\binom{10}{5}=252$."
            },
            {
                "step_id": 20,
                "edge": "The computation in Step 19 yields 252 as the count of valid lattice paths, which bijectively corresponds to zipline configurations per Step 15. Since all problem constraints (non-touching ziplines, building heights) are fully encoded in the path model, this value represents the exact number of valid configurations, presented in the required boxed format.",
                "direct_dependent_steps": [
                    19
                ],
                "node": "The final answer is \\boxed{252}."
            }
        ]
    }
]
