[
    {
        "problem_id": 663,
        "domain": [
            "Mathematics -> Discrete Mathematics -> Combinatorics"
        ],
        "difficulty": 5.0,
        "problem_text": "Massachusetts Avenue is ten blocks long. One boy and one girl live on each block. They want to form friendships such that each boy is friends with exactly one girl and vice versa. Nobody wants a friend living more than one block away (but they may be on the same block). How many pairings are possible?",
        "sample_id": 1,
        "final_answer": "The final answer is \\boxed{89}",
        "steps": [
            {
                "step_id": 1,
                "edge": "This statement establishes the problem's spatial scope as given in the problem text. Massachusetts Avenue's length of ten blocks is a foundational constraint that defines the domain for all subsequent pairing considerations, setting the upper limit for block indices we will analyze.",
                "direct_dependent_steps": null,
                "node": "Massachusetts Avenue consists of ten blocks."
            },
            {
                "step_id": 2,
                "edge": "The problem specifies one boy and one girl per block, which creates a balanced bipartite structure between boys and girls. This uniform distribution across blocks is critical because it ensures every pairing configuration must cover all individuals without surplus or deficit, forming a perfect matching requirement in combinatorial terms.",
                "direct_dependent_steps": null,
                "node": "On each block there lives one boy and one girl."
            },
            {
                "step_id": 3,
                "edge": "This constraint defines the core matching condition from the boys' perspective. Each boy must have exactly one friendship connection to a girl, establishing a bijection requirement where no boy is left unpaired and no boy has multiple partners. This is a standard perfect matching condition in bipartite graph theory.",
                "direct_dependent_steps": null,
                "node": "Each boy must be friends with exactly one girl."
            },
            {
                "step_id": 4,
                "edge": "Symmetric to Step 3, this specifies the matching condition from the girls' perspective. Combined with Step 3, it enforces a strict one-to-one correspondence between boys and girls, confirming we are counting perfect matchings rather than partial matchings or many-to-one relationships.",
                "direct_dependent_steps": null,
                "node": "Each girl must be friends with exactly one boy."
            },
            {
                "step_id": 5,
                "edge": "This distance constraint restricts possible edges in our implicit bipartite graph. Friendships can only exist between block i and blocks i-1, i, or i+1 (within bounds), which creates a narrow band of allowable connections. This locality condition is what makes the recurrence relation approach feasible, as distant blocks become decoupled in certain configurations.",
                "direct_dependent_steps": null,
                "node": "No friendship may span more than one block."
            },
            {
                "step_id": 6,
                "edge": "This clarifies that self-block friendships are permitted, which is a special case of the distance constraint in Step 5 (where distance=0). Allowing same-block pairings expands the solution space beyond strictly adjacent cross-pairings and is essential for establishing the base case a_1=1 in later steps.",
                "direct_dependent_steps": null,
                "node": "Friendships between people on the same block are allowed."
            },
            {
                "step_id": 7,
                "edge": "We introduce a recurrence variable a_n to represent the solution for n blocks, a standard dynamic programming technique for combinatorial problems with overlapping substructures. This abstraction allows us to express the solution for larger n in terms of smaller instances, leveraging the locality constraint from Step 5 to identify recursive patterns.",
                "direct_dependent_steps": null,
                "node": "Let $a_n$ denote the number of valid pairings for $n$ blocks."
            },
            {
                "step_id": 8,
                "edge": "Using the definition from Step 7, for a single block (n=1), there is only one possible pairing: the boy and girl on that block must pair together. This satisfies all constraints (Steps 3, 4, 6) since same-block friendships are permitted and no distance violations occur. Thus, a_1=1 serves as our first base case.",
                "direct_dependent_steps": [
                    7
                ],
                "node": "We have $a_1=1$."
            },
            {
                "step_id": 9,
                "edge": "For two blocks (n=2), we enumerate valid pairings per Steps 2, 3, 4, 5, and 6. Option 1: Both pairs are intra-block (block 1 boy-girl and block 2 boy-girl). Option 2: Cross-pairing where block 1 boy pairs with block 2 girl and vice versa. These are the only two configurations satisfying the distance constraint, so a_2=2 is our second base case.",
                "direct_dependent_steps": [
                    7
                ],
                "node": "We have $a_2=2$."
            },
            {
                "step_id": 10,
                "edge": "Building on the setup in Step 2 (one boy/girl per block) and Step 6 (same-block friendships allowed), we consider the case where the boy on block 1 pairs with the girl on his own block. This configuration isolates block 1's pairing, creating a self-contained unit that doesn't interact with subsequent blocks beyond block 1, which simplifies the remaining problem.",
                "direct_dependent_steps": [
                    2,
                    6
                ],
                "node": "One type of arrangement pairs the boy on block 1 with the girl on block 1."
            },
            {
                "step_id": 11,
                "edge": "After fixing the pairing for block 1 as described in Step 10, the remaining problem involves blocks 2 through n. By the definition in Step 7, this subproblem is identical to the original problem but with n-1 blocks. Therefore, the number of valid configurations for the remaining blocks is exactly a_{n-1}, as the recurrence structure preserves all constraints for the truncated avenue.",
                "direct_dependent_steps": [
                    7,
                    10
                ],
                "node": "There are $a_{n-1}$ possible pairings for the remaining $n-1$ blocks in that case."
            },
            {
                "step_id": 12,
                "edge": "Given Step 2's population structure and Step 5's distance constraint (max one-block span), we examine the alternative where block 1's boy pairs with block 2's girl. This adjacent cross-pairing is valid since it spans exactly one block, and it represents the only other possibility for block 1's boy beyond the same-block pairing in Step 10.",
                "direct_dependent_steps": [
                    2,
                    5
                ],
                "node": "Another type of arrangement pairs the boy on block 1 with the girl on block 2."
            },
            {
                "step_id": 13,
                "edge": "When block 1's boy pairs with block 2's girl (Step 12), we must satisfy Steps 3 and 4 (exactly one friend per person). The girl on block 1 cannot pair with block 1's boy (already taken) and cannot reach block 3 or beyond (Step 5), leaving only block 2's boy as her valid partner. Thus, blocks 1 and 2 become locked in a mutual cross-pairing configuration.",
                "direct_dependent_steps": [
                    3,
                    4,
                    5,
                    12
                ],
                "node": "In that arrangement the girl on block 1 must pair with the boy on block 2."
            },
            {
                "step_id": 14,
                "edge": "After resolving the interdependent pairing of blocks 1 and 2 as established in Step 13, the problem reduces to blocks 3 through n. By Step 7's definition, this is equivalent to the original problem with n-2 blocks. Therefore, the number of valid configurations for the remaining blocks is a_{n-2}, completing the second recursive case.",
                "direct_dependent_steps": [
                    7,
                    13
                ],
                "node": "There are $a_{n-2}$ possible pairings for the remaining $n-2$ blocks in that case."
            },
            {
                "step_id": 15,
                "edge": "Combining the two mutually exclusive cases from Step 11 (a_{n-1} configurations when block 1 pairs internally) and Step 14 (a_{n-2} configurations when blocks 1-2 cross-pair), we sum these disjoint possibilities to form the total count. This yields the recurrence a_n = a_{n-1} + a_{n-2}, which mirrors the Fibonacci sequence structure due to the two-term dependency.",
                "direct_dependent_steps": [
                    11,
                    14
                ],
                "node": "Therefore the recurrence relation is $a_n = a_{n-1} + a_{n-2}$."
            },
            {
                "step_id": 16,
                "edge": "Applying the recurrence from Step 15 with n=3: a_3 = a_2 + a_1. Substituting the base cases a_1=1 (Step 8) and a_2=2 (Step 9) gives 2 + 1 = 3. Manual verification for three blocks confirms this: (1) all same-block, (2) blocks 1-2 cross with block 3 same, (3) block 1 same with blocks 2-3 cross.",
                "direct_dependent_steps": [
                    8,
                    9,
                    15
                ],
                "node": "We compute $a_3 = 3$."
            },
            {
                "step_id": 17,
                "edge": "Extending the recurrence to n=4: a_4 = a_3 + a_2. Using a_3=3 (Step 16) and a_2=2 (Step 9), we compute 3 + 2 = 5. Quick validation: the five configurations correspond to the Fibonacci-like growth where each new block adds possibilities based on the prior two solutions, consistent with the recurrence logic.",
                "direct_dependent_steps": [
                    9,
                    15,
                    16
                ],
                "node": "We compute $a_4 = 5$."
            },
            {
                "step_id": 18,
                "edge": "Given Massachusetts Avenue's ten-block length (Step 1), we iteratively apply the recurrence from Step 15 starting from known values. Using a_4=5 (Step 17) and prior terms: a_5=5+3=8, a_6=8+5=13, a_7=13+8=21, a_8=21+13=34, a_9=34+21=55, a_10=55+34=89. Each step follows the Fibonacci pattern established by the recurrence, and the calculation for n=10 yields the final count of 89 valid pairings.",
                "direct_dependent_steps": [
                    1,
                    15,
                    17
                ],
                "node": "Continuing this pattern yields $a_{10} = 89$."
            }
        ]
    }
]
