[
    {
        "problem_id": 121,
        "domain": [
            "Mathematics -> Discrete Mathematics -> Graph Theory"
        ],
        "difficulty": 5.25,
        "problem_text": "In the country of Francisca, there are 2010 cities, some of which are connected by roads. Between any two cities, there is a unique path which runs along the roads and which does not pass through any city twice. What is the maximum possible number of cities in Francisca which have at least 3 roads running out of them?",
        "sample_id": 1,
        "final_answer": "The final answer is $\\boxed{1004}$.}",
        "steps": [
            {
                "step_id": 1,
                "edge": "We identify the graph structure based on the problem statement: the condition that between any two cities there is a unique path without repeating cities defines a tree, as trees are precisely the connected acyclic graphs where such unique paths exist between all vertex pairs.",
                "direct_dependent_steps": null,
                "node": "The graph of the $2010$ cities with roads as edges is a tree."
            },
            {
                "step_id": 2,
                "edge": "Building on Step 1 which confirms the graph is a tree, we apply the fundamental tree property that any tree with $n$ vertices has exactly $n-1$ edges. Substituting $n=2010$ gives $2010-1=2009$ edges.",
                "direct_dependent_steps": [
                    1
                ],
                "node": "A tree on $2010$ vertices has $2009$ edges."
            },
            {
                "step_id": 3,
                "edge": "This step cites the handshaking lemma, a core graph theory theorem stating that for any finite graph, the sum of all vertex degrees equals twice the number of edges, which follows from each edge contributing exactly two to the total degree count (one for each endpoint).",
                "direct_dependent_steps": null,
                "node": "The sum of the degrees of the vertices in any graph equals $2$ times the number of edges."
            },
            {
                "step_id": 4,
                "edge": "Combining Step 2 (which gives 2009 edges) and Step 3 (the handshaking lemma), we compute the total degree sum as $2 \\times 2009$, since the lemma requires multiplying the edge count by 2.",
                "direct_dependent_steps": [
                    2,
                    3
                ],
                "node": "Therefore the sum of the degrees of the vertices in this tree equals $2\\times2009$."
            },
            {
                "step_id": 5,
                "edge": "We evaluate the expression from Step 4: $2 \\times 2009 = 4018$. Verification: $2 \\times 2000 = 4000$ and $2 \\times 9 = 18$, so $4000 + 18 = 4018$, confirming the arithmetic is correct.",
                "direct_dependent_steps": [
                    4
                ],
                "node": "The value of $2\\times2009$ is $4018$."
            },
            {
                "step_id": 6,
                "edge": "We introduce $b$ as a variable to represent the count of vertices with degree at least 3, which is the quantity we need to maximize for the problem's objective, establishing a clear target for subsequent reasoning.",
                "direct_dependent_steps": null,
                "node": "Let $b$ denote the number of vertices in this tree whose degree is at least $3$."
            },
            {
                "step_id": 7,
                "edge": "This step relies on a basic tree property: in any tree with more than one vertex, all vertices must have degree at least 1 to maintain connectivity (since isolated vertices would violate the unique path condition), and here $2010 > 1$ satisfies the condition.",
                "direct_dependent_steps": null,
                "node": "Every vertex in a tree on more than one vertex has degree at least $1$."
            },
            {
                "step_id": 8,
                "edge": "Using Step 6 (which defines $b$ as vertices with degree $\\geq 3$) and Step 7 (which ensures all vertices have degree $\\geq 1$), we deduce that the remaining $2010 - b$ vertices—those not counted in $b$—must have degree between 1 and 2 inclusive, hence each contributes at least 1 to the degree sum.",
                "direct_dependent_steps": [
                    6,
                    7
                ],
                "node": "Thus each of the remaining $2010 - b$ vertices has degree at least $1$."
            },
            {
                "step_id": 9,
                "edge": "Based on Step 6 (where $b$ vertices have degree $\\geq 3$), we establish a lower bound for their total degree contribution by assuming the minimal possible degree (3) for each, yielding $3b$ as the smallest possible sum from these vertices.",
                "direct_dependent_steps": [
                    6
                ],
                "node": "The contribution to the total degree sum from the $b$ vertices of degree at least $3$ is at least $3b$."
            },
            {
                "step_id": 10,
                "edge": "From Step 8 (which states each of the $2010 - b$ vertices has degree $\\geq 1$), we derive a lower bound for their total degree contribution as $1 \\times (2010 - b)$, using the minimal degree value to ensure the bound holds for all valid trees.",
                "direct_dependent_steps": [
                    8
                ],
                "node": "The contribution to the total degree sum from the remaining $2010 - b$ vertices is at least $1\\times(2010 - b)$."
            },
            {
                "step_id": 11,
                "edge": "We combine the lower bounds from Step 9 (contribution $\\geq 3b$ from high-degree vertices) and Step 10 (contribution $\\geq 2010 - b$ from other vertices) to form a composite lower bound for the total degree sum: $3b + (2010 - b)$, which must be less than or equal to the actual sum.",
                "direct_dependent_steps": [
                    9,
                    10
                ],
                "node": "Hence the total degree sum is at least $3b + (2010 - b)$."
            },
            {
                "step_id": 12,
                "edge": "We simplify the expression $3b + (2010 - b)$ from Step 11 through basic algebra: combining like terms gives $3b - b + 2010 = 2b + 2010$, which is a cleaner form for the lower bound.",
                "direct_dependent_steps": [
                    11
                ],
                "node": "The expression $3b + (2010 - b)$ simplifies to $2b + 2010$."
            },
            {
                "step_id": 13,
                "edge": "We relate the lower bound from Step 12 ($2b + 2010$) to the exact total degree sum from Step 5 (4018), establishing the inequality $2b + 2010 \\leq 4018$ because the actual sum must be at least as large as any valid lower bound.",
                "direct_dependent_steps": [
                    5,
                    12
                ],
                "node": "Since the total degree sum is $4018$, we have $2b + 2010 \\le 4018$."
            },
            {
                "step_id": 14,
                "edge": "Starting from the inequality in Step 13 ($2b + 2010 \\leq 4018$), we isolate the $b$-term by subtracting 2010 from both sides, yielding $2b \\leq 4018 - 2010 = 2008$, a necessary simplification before solving for $b$.",
                "direct_dependent_steps": [
                    13
                ],
                "node": "Subtracting $2010$ from both sides of $2b + 2010 \\le 4018$ yields $2b \\le 2008$."
            },
            {
                "step_id": 15,
                "edge": "We solve for $b$ in Step 14's inequality ($2b \\leq 2008$) by dividing both sides by 2, resulting in $b \\leq 1004$. This gives the theoretical upper bound for the number of vertices with degree at least 3.",
                "direct_dependent_steps": [
                    14
                ],
                "node": "Dividing both sides of $2b \\le 2008$ by $2$ yields $b \\le 1004$."
            },
            {
                "step_id": 16,
                "edge": "To verify achievability of the bound from Step 15 ($b \\leq 1004$), we construct a candidate degree sequence: 1004 vertices of degree 3 (to maximize $b$) and $2010 - 1004 = 1006$ vertices of degree 1 (the minimal allowed degree from Step 7).",
                "direct_dependent_steps": [
                    15
                ],
                "node": "Consider the sequence consisting of $1004$ entries equal to $3$ and $1006$ entries equal to $1$."
            },
            {
                "step_id": 17,
                "edge": "We compute the sum of the sequence proposed in Step 16: 1004 vertices at degree 3 contribute $1004 \\times 3$, and 1006 vertices at degree 1 contribute $1006 \\times 1$, so the total is $1004 \\times 3 + 1006 \\times 1$.",
                "direct_dependent_steps": [
                    16
                ],
                "node": "The sum of this sequence equals $1004\\times3 + 1006\\times1$."
            },
            {
                "step_id": 18,
                "edge": "Evaluating the expression from Step 17: $1004 \\times 3 = 3012$ and $1006 \\times 1 = 1006$, so $3012 + 1006 = 4018$. Sanity check: $1000 \\times 3 = 3000$, $4 \\times 3 = 12$, $3000 + 12 = 3012$; $1000 \\times 1 = 1000$, $6 \\times 1 = 6$, $1000 + 6 = 1006$; $3012 + 1006 = 4018$, matching Step 5.",
                "direct_dependent_steps": [
                    17
                ],
                "node": "The value of $1004\\times3 + 1006\\times1$ is $4018$."
            },
            {
                "step_id": 19,
                "edge": "Since Step 18 confirms the sum is 4018 and we know $2 \\times (2010 - 1) = 2 \\times 2009 = 4018$ (from Steps 2 and 4), we rewrite the sum as $2 \\times (2010 - 1)$ to connect with tree degree sequence requirements.",
                "direct_dependent_steps": [
                    18
                ],
                "node": "Therefore the sum of this sequence equals $2\\times(2010 - 1)$."
            },
            {
                "step_id": 20,
                "edge": "Step 19 shows the sequence sums to $2 \\times (2010 - 1)$, which satisfies the necessary and sufficient condition for a degree sequence to form a tree (positive integers summing to $2(n-1)$ for $n$ vertices), guaranteeing such a tree exists.",
                "direct_dependent_steps": [
                    19
                ],
                "node": "Any sequence of positive integers of length $2010$ summing to $2\\times(2010 - 1)$ is the degree sequence of some tree on $2010$ vertices."
            },
            {
                "step_id": 21,
                "edge": "Combining Step 16 (which specifies 1004 vertices of degree 3 and 1006 of degree 1) and Step 20 (which confirms this sequence forms a tree), we conclude the constructed tree has exactly 1004 vertices with degree at least 3, achieving the bound from Step 15.",
                "direct_dependent_steps": [
                    16,
                    20
                ],
                "node": "In such a tree, exactly $1004$ vertices have degree at least $3$."
            },
            {
                "step_id": 22,
                "edge": "We synthesize Step 15 (which proves $b \\leq 1004$ is necessary) and Step 21 (which demonstrates $b = 1004$ is achievable), establishing 1004 as the maximum possible number of cities with at least 3 roads, which is the solution to the problem.",
                "direct_dependent_steps": [
                    15,
                    21
                ],
                "node": "The final answer is $\\boxed{1004}$."
            }
        ]
    }
]
