[
    {
        "problem_id": 2466,
        "domain": [
            "Mathematics -> Discrete Mathematics -> Graph Theory",
            "Mathematics -> Applied Mathematics -> Statistics -> Probability -> Counting Methods -> Combinations"
        ],
        "difficulty": 4.0,
        "problem_text": "There are 5 students on a team for a math competition. The math competition has 5 subject tests. Each student on the team must choose 2 distinct tests, and each test must be taken by exactly two people. In how many ways can this be done?",
        "sample_id": 1,
        "final_answer": "2040",
        "steps": [
            {
                "step_id": 1,
                "edge": "This step states the fundamental premise given in the problem: there are exactly 5 students on the team. As a direct input condition with no prior dependencies, this establishes the size of the student group we must assign to tests.",
                "direct_dependent_steps": null,
                "node": "There are 5 students on the team."
            },
            {
                "step_id": 2,
                "edge": "This step states the complementary premise from the problem: there are exactly 5 subject tests in the competition. Like Step 1, this is a direct problem input with no dependencies, defining the pool of tests to be assigned.",
                "direct_dependent_steps": null,
                "node": "There are 5 tests in the competition."
            },
            {
                "step_id": 3,
                "edge": "This step captures the problem's constraint that each student must select 2 distinct tests. As a given condition with no dependencies, this dictates the required degree of each student vertex in the subsequent bipartite graph model and ensures we avoid invalid single-test or repeated-test assignments.",
                "direct_dependent_steps": null,
                "node": "Each student selects 2 distinct tests."
            },
            {
                "step_id": 4,
                "edge": "This step records the critical problem constraint that every test must be selected by exactly 2 students. With no dependencies, this specifies the required degree for each test vertex in the bipartite graph representation and ensures full coverage of all tests without over- or under-subscription.",
                "direct_dependent_steps": null,
                "node": "Each test is selected by exactly 2 students."
            },
            {
                "step_id": 5,
                "edge": "We model the assignment problem as a bipartite graph to structurally represent the constraints from Steps 1–4. The student set (Step 1) and test set (Step 2) form the two partitions, with edges encoding test selections. Each student's two selections (Step 3) become degree-2 student vertices, and each test being chosen twice (Step 4) becomes degree-2 test vertices. This graph-theoretic translation converts the combinatorial problem into analyzing regular bipartite graphs.",
                "direct_dependent_steps": [
                    1,
                    2,
                    3,
                    4
                ],
                "node": "We represent each assignment by an edge in a bipartite graph between student and test vertices."
            },
            {
                "step_id": 6,
                "edge": "Building on the bipartite graph model from Step 5, we specify its vertex structure: 5 student vertices (from Step 1) and 5 test vertices (from Step 2). This confirms the graph is balanced (5+5 vertices), which is essential for later cycle decomposition arguments since unbalanced partitions would preclude 2-regularity with equal degrees.",
                "direct_dependent_steps": [
                    1,
                    2,
                    5
                ],
                "node": "This bipartite graph has 5 student vertices and 5 test vertices."
            },
            {
                "step_id": 7,
                "edge": "Each student vertex must have degree 2 because every student selects exactly 2 tests (Step 3), as directly encoded in the bipartite graph representation (Step 5). This degree constraint is fundamental to recognizing the graph as 2-regular, which dictates its cycle structure in subsequent steps.",
                "direct_dependent_steps": [
                    3,
                    5
                ],
                "node": "Each student vertex has degree 2 in this graph."
            },
            {
                "step_id": 8,
                "edge": "Each test vertex must have degree 2 because every test is selected by exactly 2 students (Step 4), per the bipartite graph's edge definition (Step 5). This symmetric degree condition (matching Step 7 for students) ensures the graph is 2-regular bipartite, a key property for cycle decomposition.",
                "direct_dependent_steps": [
                    4,
                    5
                ],
                "node": "Each test vertex has degree 2 in this graph."
            },
            {
                "step_id": 9,
                "edge": "A 2-regular graph (where all vertices have degree 2) must decompose into disjoint cycles covering all vertices. Since the graph is bipartite (Step 5) with partitions of equal size (Step 6), all cycles must be of even length—this follows from the bipartite graph property that cycles alternate between partitions, requiring even lengths to return to the starting partition. Steps 7 and 8 confirm the 2-regularity enabling this decomposition.",
                "direct_dependent_steps": [
                    5,
                    7,
                    8
                ],
                "node": "A 2-regular bipartite simple graph decomposes into even cycles."
            },
            {
                "step_id": 10,
                "edge": "The graph cannot contain 2-cycles (two edges between the same student-test pair) because the problem requires distinct test selections per student (Step 3) and the bipartite graph representation (Step 5) is simple (no parallel edges). Step 9's cycle decomposition must therefore exclude 2-cycles, restricting possible cycle lengths to 4 or greater even numbers.",
                "direct_dependent_steps": [
                    5,
                    9
                ],
                "node": "The graph cannot contain any 2-cycles because parallel edges are not allowed."
            },
            {
                "step_id": 11,
                "edge": "With 10 total vertices (5 students + 5 tests from Step 6), Step 9's even-cycle decomposition must cover all vertices. Step 10 eliminates 2-cycles, leaving only two valid partitions of 10 into even integers ≥4: a single 10-cycle, or a 4-cycle paired with a 6-cycle (since 2+8 is invalid due to 2-cycles and 6+4 is equivalent to 4+6). These are the only structurally possible configurations satisfying all constraints.",
                "direct_dependent_steps": [
                    6,
                    9,
                    10
                ],
                "node": "Therefore the graph consists of either one 10-cycle or one 4-cycle and one 6-cycle."
            },
            {
                "step_id": 12,
                "edge": "To compute the total valid assignments, we first enumerate the 10-cycle case identified in Step 11. Step 6 confirms the 10-vertex structure, making this a Hamiltonian cycle counting problem on the complete bipartite graph K_{5,5}. We focus on labeled alternating cycles (student-test-student-test) as required by the bipartite model.",
                "direct_dependent_steps": [
                    6,
                    11
                ],
                "node": "We first count the number of labeled alternating 10-cycles on the 5 student and 5 test vertices."
            },
            {
                "step_id": 13,
                "edge": "The count of distinct labeled alternating 10-cycles follows from combinatorial cycle-counting principles: 5! orders the student vertices and 5! orders the test vertices in a cyclic sequence, but each unique cycle is overcounted by a factor of 10 (the cycle length) due to rotational symmetry (any of the 10 vertices can be the starting point). Dividing 5!×5! by 10 corrects for this overcounting, yielding the precise count for Step 12's objective.",
                "direct_dependent_steps": [
                    12
                ],
                "node": "The number of alternating 10-cycles on 5 students and 5 tests is \\(\\frac{5!\\,5!}{10}\\)."
            },
            {
                "step_id": 14,
                "edge": "We compute 5! = 120 as the foundational factorial for permutations of 5 elements. This value is necessary for Step 13's cycle-counting formula and serves as a building block for subsequent multiplications. Verification: 5×4×3×2×1 = 120 confirms the standard factorial result.",
                "direct_dependent_steps": [
                    13
                ],
                "node": "We compute \\(5! = 120\\)."
            },
            {
                "step_id": 15,
                "edge": "Multiplying the Step 14 results: 120 (student permutations) × 120 (test permutations) = 14,400. This represents the total unadjusted sequences before accounting for cycle symmetry. Sanity check: 100×100=10,000 and 20×120=2,400, but precise calculation 120² = (100+20)² = 10,000 + 4,000 + 400 = 14,400 validates the product.",
                "direct_dependent_steps": [
                    14
                ],
                "node": "We compute \\(120\\times 120 = 14400\\)."
            },
            {
                "step_id": 16,
                "edge": "Applying Step 13's symmetry adjustment, we divide Step 15's 14,400 by 10 (the cycle length): 14,400 ÷ 10 = 1,440. This corrects for rotational overcounting in cycle enumeration. Verification: 1,440 × 10 = 14,400 confirms the arithmetic accuracy, yielding the count of unique 10-cycle assignments.",
                "direct_dependent_steps": [
                    13,
                    15
                ],
                "node": "We compute \\(\\frac{14400}{10} = 1440\\)."
            },
            {
                "step_id": 17,
                "edge": "This step consolidates Step 16's numerical result: the 1,440 computed assignments correspond precisely to all valid configurations where the bipartite graph forms a single 10-cycle, as enumerated in Steps 12–16. No additional dependencies are needed since this directly reports the calculation outcome.",
                "direct_dependent_steps": [
                    16
                ],
                "node": "Therefore there are 1440 assignments corresponding to a single 10-cycle."
            },
            {
                "step_id": 18,
                "edge": "Having resolved the 10-cycle case, we now address the alternative structure from Step 11: a 4-cycle paired with a 6-cycle. This step initiates the counting process for this second case, which requires partitioning vertices between the two cycles while respecting the bipartite constraints.",
                "direct_dependent_steps": [
                    11
                ],
                "node": "Next we count assignments corresponding to a 4-cycle and a 6-cycle."
            },
            {
                "step_id": 19,
                "edge": "To isolate the 4-cycle component, we choose 2 students out of 5 for its student partition. Step 6 confirms the 5-student pool, and Step 18 defines the context of partitioning for the 4/6-cycle case. The binomial coefficient \\(\\binom{5}{2}\\) counts these combinations without regard to order, as required for subset selection.",
                "direct_dependent_steps": [
                    6,
                    18
                ],
                "node": "We choose 2 students out of 5 for the 4-cycle in \\(\\binom{5}{2}\\) ways."
            },
            {
                "step_id": 20,
                "edge": "Similarly, we choose 2 tests out of 5 for the 4-cycle's test partition. Step 6 provides the 5-test pool, and Step 18 sets the context for the 4/6-cycle decomposition. Using \\(\\binom{5}{2}\\) ensures we count all valid test subsets for the smaller cycle while maintaining bipartite alignment with Step 19's student selection.",
                "direct_dependent_steps": [
                    6,
                    18
                ],
                "node": "We choose 2 tests out of 5 for the 4-cycle in \\(\\binom{5}{2}\\) ways."
            },
            {
                "step_id": 21,
                "edge": "We compute \\(\\binom{5}{2} = \\frac{5×4}{2×1} = 10\\), the number of ways to choose 2 items from 5. This follows directly from the binomial coefficient formula applied to Step 19's student selection context. Verification: listing pairs for 5 elements confirms exactly 10 unique combinations.",
                "direct_dependent_steps": [
                    19
                ],
                "node": "We compute \\(\\binom{5}{2} = 10\\)."
            },
            {
                "step_id": 22,
                "edge": "Multiplying Step 21's results: 10 (student pairs) × 10 (test pairs) = 100. This gives the total ways to select the 4-cycle's vertex subsets. The multiplication principle applies here since student and test selections are independent choices, as established in Steps 19 and 20.",
                "direct_dependent_steps": [
                    21
                ],
                "node": "We compute \\(10\\times 10 = 100\\)."
            },
            {
                "step_id": 23,
                "edge": "For the chosen 2 students (Step 19) and 2 tests (Step 20), we count alternating 4-cycles in their K_{2,2} subgraph. The formula \\(\\frac{2!\\,2!}{4}\\) arises because 2! orders the students and 2! orders the tests in a sequence, but each unique 4-cycle is overcounted 4 times (once per starting vertex). This adjustment yields the exact cycle count for this minimal bipartite graph.",
                "direct_dependent_steps": [
                    19,
                    20
                ],
                "node": "The number of alternating 4-cycles on the chosen 2 students and 2 tests is \\(\\frac{2!\\,2!}{4}\\)."
            },
            {
                "step_id": 24,
                "edge": "We compute 2! = 2, the factorial for 2 elements. This simple calculation supports Step 23's cycle-counting formula and is verified by 2×1 = 2. As a foundational value, it enables the subsequent product in Step 25.",
                "direct_dependent_steps": [
                    23
                ],
                "node": "We compute \\(2! = 2\\)."
            },
            {
                "step_id": 25,
                "edge": "Multiplying Step 24's results: 2 × 2 = 4. This gives the unadjusted permutation count (2!×2!) for the K_{2,2} subgraph's vertex orderings. Verification: 2×2 is trivially 4, matching the total possible bijections between two 2-element sets.",
                "direct_dependent_steps": [
                    24
                ],
                "node": "We compute \\(2\\times 2 = 4\\)."
            },
            {
                "step_id": 26,
                "edge": "Applying Step 23's symmetry adjustment, we divide Step 25's 4 by 4 (the cycle length): 4 ÷ 4 = 1. This confirms there is exactly one distinct alternating 4-cycle in K_{2,2}, which aligns with the known structure of complete bipartite graphs (K_{2,2} is itself a 4-cycle). Verification: 1×4=4 confirms the division.",
                "direct_dependent_steps": [
                    23,
                    25
                ],
                "node": "We compute \\(\\frac{4}{4} = 1\\)."
            },
            {
                "step_id": 27,
                "edge": "For the remaining 3 students and 3 tests (isolated by Step 18's partitioning), we count alternating 6-cycles using the same cycle-counting principle as Step 12. The formula \\(\\frac{3!\\,3!}{6}\\) accounts for permutations of the 3 students and tests, divided by 6 to correct for rotational symmetry in 6-cycles, analogous to Step 13's 10-cycle adjustment.",
                "direct_dependent_steps": [
                    12,
                    18
                ],
                "node": "The number of alternating 6-cycles on the remaining 3 students and 3 tests is \\(\\frac{3!\\,3!}{6}\\)."
            },
            {
                "step_id": 28,
                "edge": "We compute 3! = 6, the factorial for 3 elements. This follows from 3×2×1 = 6 and supports Step 27's cycle-counting formula. Verification: standard factorial calculation confirms this intermediate value for permutations.",
                "direct_dependent_steps": [
                    27
                ],
                "node": "We compute \\(3! = 6\\)."
            },
            {
                "step_id": 29,
                "edge": "Multiplying Step 28's results: 6 × 6 = 36. This gives the unadjusted permutation count (3!×3!) for the 3-student and 3-test orderings. Verification: 6×6=36 is a basic arithmetic fact, consistent with the product of two identical factorials.",
                "direct_dependent_steps": [
                    28
                ],
                "node": "We compute \\(6\\times 6 = 36\\)."
            },
            {
                "step_id": 30,
                "edge": "Applying Step 27's symmetry adjustment, we divide Step 29's 36 by 6 (the cycle length): 36 ÷ 6 = 6. This yields the count of unique alternating 6-cycles for the 3×3 subgraph. Verification: 6×6=36 confirms the division, and combinatorial knowledge of K_{3,3} Hamiltonian cycles validates the result.",
                "direct_dependent_steps": [
                    27,
                    29
                ],
                "node": "We compute \\(\\frac{36}{6} = 6\\)."
            },
            {
                "step_id": 31,
                "edge": "We combine all components for the 4/6-cycle case using the multiplication principle: Step 22's 100 (vertex subset choices) × Step 26's 1 (4-cycle count) × Step 30's 6 (6-cycle count). This product accounts for independent choices in partitioning vertices and enumerating cycles within each partition, as established in Steps 18–30.",
                "direct_dependent_steps": [
                    22,
                    26,
                    30
                ],
                "node": "Therefore the total number of assignments for the 4-cycle and 6-cycle case is \\(100 \\times 1 \\times 6\\)."
            },
            {
                "step_id": 32,
                "edge": "We compute the first multiplication from Step 31: 100 × 1 = 100. This intermediate step simplifies the expression by incorporating the 4-cycle count (Step 26). Verification: multiplying by 1 preserves the value, confirming 100 is correct.",
                "direct_dependent_steps": [
                    31
                ],
                "node": "We compute \\(100\\times 1 = 100\\)."
            },
            {
                "step_id": 33,
                "edge": "Completing Step 31's product, we compute 100 (from Step 32) × 6 (from Step 30) = 600. This gives the total assignments for the 4/6-cycle configuration. Verification: 100×6=600 is a straightforward multiplication, and cross-checking with Step 31's components ensures no arithmetic errors.",
                "direct_dependent_steps": [
                    30,
                    32
                ],
                "node": "We compute \\(100\\times 6 = 600\\)."
            },
            {
                "step_id": 34,
                "edge": "The total valid assignments combine both structural cases: Step 17's 1,440 (10-cycle) + Step 33's 600 (4/6-cycle). This addition follows the principle of counting disjoint cases (Step 11 confirmed these are the only two possibilities), ensuring all valid configurations are included without overlap.",
                "direct_dependent_steps": [
                    17,
                    33
                ],
                "node": "The total number of valid assignments is \\(1440 + 600\\)."
            },
            {
                "step_id": 35,
                "edge": "Summing Step 34's components: 1,440 + 600 = 2,040. This final arithmetic combines both cycle-structure cases. Verification: 1,400+600=2,000 and 40+0=40, so 2,000+40=2,040 confirms the addition, yielding the total assignment count.",
                "direct_dependent_steps": [
                    34
                ],
                "node": "We compute \\(1440 + 600 = 2040\\)."
            },
            {
                "step_id": 36,
                "edge": "This step presents the final answer derived from Step 35's calculation. The value 2,040 represents the complete count of valid test assignments satisfying all problem constraints, as rigorously enumerated through bipartite graph cycle decomposition and combinatorial counting in all prior steps.",
                "direct_dependent_steps": [
                    35
                ],
                "node": "The final answer is \\boxed{2040}"
            }
        ]
    }
]
