[
    {
        "problem_id": 2791,
        "domain": [
            "Mathematics -> Discrete Mathematics -> Graph Theory"
        ],
        "difficulty": 6.0,
        "problem_text": "A new website registered $2000$ people. Each of them invited $1000$ other registered people to be their friends. Two people are considered to be friends if and only if they have invited each other. What is the minimum number of pairs of friends on this website?",
        "sample_id": 1,
        "final_answer": "$1000$",
        "steps": [
            {
                "step_id": 1,
                "edge": "We establish $n$ as the total number of registered users, which is given directly in the problem statement as 2000. This definition provides a foundational variable for subsequent mathematical modeling, allowing us to abstract the concrete number into a symbolic form for general reasoning while preserving the specific value for later substitution.",
                "direct_dependent_steps": null,
                "node": "Let $n$ be $2000$, the number of registered people."
            },
            {
                "step_id": 2,
                "edge": "We define $k$ as the fixed number of invitations each user sends, explicitly stated in the problem as 1000. This parameter captures the uniform invitation behavior across all users and serves as a critical constant in calculating edge counts within our graph representation.",
                "direct_dependent_steps": null,
                "node": "Let $k$ be $1000$, the number of invitations each person sends."
            },
            {
                "step_id": 3,
                "edge": "To model the invitation system, we represent each ordered invitation as a directed edge in a graph where vertices correspond to users. This transformation leverages graph theory principles to convert the social network problem into a combinatorial structure, where mutual invitations (friendships) will later correspond to bidirectional edges between vertex pairs.",
                "direct_dependent_steps": null,
                "node": "For each ordered invitation from one person to another, we draw a directed edge."
            },
            {
                "step_id": 4,
                "edge": "Building on Steps 1, 2, and 3, we calculate the total directed edges by recognizing that each of the $n$ users sends exactly $k$ invitations. The multiplication principle applies here: since every invitation is a distinct directed edge and there are no overlaps in counting (each invitation originates from one user), the total is $n \\times k$. This follows directly from the definition of outdegree sum in directed graphs.",
                "direct_dependent_steps": [
                    1,
                    2,
                    3
                ],
                "node": "The total number of directed edges equals $n \\times k$."
            },
            {
                "step_id": 5,
                "edge": "Using the expression $n \\times k$ from Step 4, we substitute the given values $n=2000$ and $k=1000$. Performing the arithmetic: $2000 \\times 1000 = 2,000,000$. A quick sanity check confirms $2000 \\times 1000$ is indeed two million, as multiplying by 1000 appends three zeros to 2000.",
                "direct_dependent_steps": [
                    4
                ],
                "node": "Substituting $n=2000$ and $k=1000$ gives $n \\times k = 2{,}000{,}000$."
            },
            {
                "step_id": 6,
                "edge": "Extending the graph model from Step 3, we analyze unordered user pairs. For any pair, the possible invitation configurations are: zero edges (no invitations), one edge (invitation in one direction only), or two edges (mutual invitations). This partitioning is exhaustive and mutually exclusive, forming the basis for categorizing all possible pairwise relationships.",
                "direct_dependent_steps": [
                    3
                ],
                "node": "For each unordered pair of people, define $0$, $1$, or $2$ directed edges between them."
            },
            {
                "step_id": 7,
                "edge": "Based on Step 6's categorization, we define $m$ as the count of unordered pairs with exactly two directed edges. This variable specifically tracks mutual invitation pairs, which by the problem's definition constitute 'friends'—the central quantity we aim to minimize in the solution.",
                "direct_dependent_steps": [
                    6
                ],
                "node": "Let $m$ denote the number of unordered pairs that have exactly $2$ directed edges."
            },
            {
                "step_id": 8,
                "edge": "Following Step 6's framework, we introduce $u$ to represent the number of unordered pairs with precisely one directed edge. This captures asymmetric invitation scenarios where one user invited the other but not vice versa, which must be accounted for in the total edge count.",
                "direct_dependent_steps": [
                    6
                ],
                "node": "Let $u$ denote the number of unordered pairs that have exactly $1$ directed edge."
            },
            {
                "step_id": 9,
                "edge": "Consistent with Step 6's classification, we let $z$ denote the count of unordered pairs with no directed edges. This represents completely disconnected user pairs with no invitations in either direction, and like $u$, it contributes to the partitioning of all possible pairs.",
                "direct_dependent_steps": [
                    6
                ],
                "node": "Let $z$ denote the number of unordered pairs that have exactly $0$ directed edges."
            },
            {
                "step_id": 10,
                "edge": "Since Steps 7, 8, and 9 collectively partition all unordered user pairs into disjoint categories (two-edge, one-edge, and zero-edge pairs), their sum $m + u + z$ must equal the total number of unordered pairs. This is a direct application of the addition principle for disjoint sets in combinatorics.",
                "direct_dependent_steps": [
                    7,
                    8,
                    9
                ],
                "node": "The sum $m+u+z$ equals the total number of unordered pairs."
            },
            {
                "step_id": 11,
                "edge": "The total number of unordered pairs among $n$ users is given by the binomial coefficient $\\binom{n}{2}$, a standard combinatorial formula for choosing 2 distinct elements from $n$. Step 1 provides $n=2000$, and Step 10 establishes that this total equals $m + u + z$, so we equate the two expressions to form a key equation.",
                "direct_dependent_steps": [
                    1,
                    10
                ],
                "node": "The total number of unordered pairs equals \\(\\binom{n}{2}\\)."
            },
            {
                "step_id": 12,
                "edge": "Substituting $n=2000$ into $\\binom{n}{2}$ from Step 11 yields $\\frac{2000 \\times 1999}{2} = 1,999,000$. Verifying the arithmetic: $2000 \\times 1999 = 3,998,000$, and dividing by 2 gives $1,999,000$, which aligns with the combinatorial interpretation of pairwise combinations.",
                "direct_dependent_steps": [
                    11
                ],
                "node": "Substituting $n=2000$ gives \\(\\binom{2000}{2}=1{,}999{,}000\\)."
            },
            {
                "step_id": 13,
                "edge": "Combining Step 10's partition equation $m + u + z$ with Step 12's numerical value for the total pairs, we obtain $m + u + z = 1,999,000$. This equation relates our three key variables and will later be used in conjunction with the edge count equation to isolate $m$.",
                "direct_dependent_steps": [
                    10,
                    12
                ],
                "node": "Therefore $m+u+z = 1{,}999{,}000$."
            },
            {
                "step_id": 14,
                "edge": "Referencing Step 6's pair categorization, each unordered pair with two directed edges contributes exactly two to the total outdegree sum (one from each direction). This follows directly from the definition of outdegree: every directed edge originating from a vertex increments the outdegree sum by one, and mutual pairs generate two such edges.",
                "direct_dependent_steps": [
                    6
                ],
                "node": "Each pair with $2$ edges contributes $2$ to the outdegree sum."
            },
            {
                "step_id": 15,
                "edge": "Per Step 6's classification, a pair with exactly one directed edge contributes precisely one to the outdegree sum, as only one invitation exists (e.g., from user A to B but not B to A). This contribution is inherent to the directed edge model established in Step 3.",
                "direct_dependent_steps": [
                    6
                ],
                "node": "Each pair with $1$ edge contributes $1$ to the outdegree sum."
            },
            {
                "step_id": 16,
                "edge": "As defined in Step 6, pairs with zero directed edges contribute nothing to the outdegree sum since no invitations exist between them. This is consistent with the outdegree sum being the total count of directed edges, which requires at least one edge per contributing pair.",
                "direct_dependent_steps": [
                    6
                ],
                "node": "Each pair with $0$ edges contributes $0$ to the outdegree sum."
            },
            {
                "step_id": 17,
                "edge": "Summing the contributions from Steps 14, 15, and 16: the $m$ two-edge pairs contribute $2m$, the $u$ one-edge pairs contribute $u$, and the $z$ zero-edge pairs contribute $0$. Thus the total outdegree sum simplifies to $2m + u$, providing a compact expression for the edge count in terms of our partition variables.",
                "direct_dependent_steps": [
                    14,
                    15,
                    16
                ],
                "node": "Hence the outdegree sum equals $2m+u$."
            },
            {
                "step_id": 18,
                "edge": "The outdegree sum was previously calculated in Steps 4 and 5 as $n \\times k = 2,000,000$, since it equals the total number of directed edges (each invitation is an outedge for one user). This value serves as a fixed constraint derived from the problem's invitation rules.",
                "direct_dependent_steps": [
                    4,
                    5
                ],
                "node": "The outdegree sum has already been calculated as $2{,}000{,}000$."
            },
            {
                "step_id": 19,
                "edge": "Equating the expression from Step 17 ($2m + u$) with the known outdegree sum from Step 18 ($2,000,000$), we establish $2m + u = 2,000,000$. This equation, combined with the pair count equation from Step 13, forms a system that will allow us to solve for $m$.",
                "direct_dependent_steps": [
                    17,
                    18
                ],
                "node": "Therefore $2m+u = 2{,}000{,}000$."
            },
            {
                "step_id": 20,
                "edge": "Subtracting the pair count equation ($m + u + z = 1,999,000$ from Step 13) from the edge count equation ($2m + u = 2,000,000$ from Step 19) eliminates $u$: $(2m + u) - (m + u + z) = 2,000,000 - 1,999,000$, simplifying to $m - z = 1,000$. This algebraic manipulation isolates $m$ relative to $z$.",
                "direct_dependent_steps": [
                    13,
                    19
                ],
                "node": "Subtracting the equation $m+u+z = 1{,}999{,}000$ from $2m+u = 2{,}000{,}000$ yields $m - z = 1{,}000$."
            },
            {
                "step_id": 21,
                "edge": "Since $z$ represents a count of unordered pairs (Step 9), it must be non-negative ($z \\geq 0$). From Step 20's equation $m - z = 1,000$, rearranging gives $m = 1,000 + z$. Therefore, $m \\geq 1,000$ because $z$ cannot reduce $m$ below 1,000. This establishes a lower bound for $m$.",
                "direct_dependent_steps": [
                    9,
                    20
                ],
                "node": "Since $z \\ge 0$, we deduce $m \\ge 1{,}000$."
            },
            {
                "step_id": 22,
                "edge": "Given Step 21's deduction that $m \\geq 1,000$, the minimum possible value of $m$ is exactly 1,000—achieved when $z = 0$. However, we must verify this minimum is attainable through a valid invitation configuration before concluding it is feasible.",
                "direct_dependent_steps": [
                    21
                ],
                "node": "Therefore the minimum possible value of $m$ equals $1{,}000$."
            },
            {
                "step_id": 23,
                "edge": "To confirm the minimum from Step 22 is achievable, we must construct a specific invitation scheme where $m = 1,000$. This requires demonstrating a concrete example satisfying all problem constraints (2000 users, 1000 invitations per user) while yielding exactly 1000 mutual invitation pairs.",
                "direct_dependent_steps": [
                    22
                ],
                "node": "It remains to show that $m = 1{,}000$ is attainable."
            },
            {
                "step_id": 24,
                "edge": "Following Step 23's requirement for a constructive proof and using Step 1's $n=2000$, we label users $0$ through $1999$ for precise mathematical description. This cyclic labeling facilitates modular arithmetic in defining the invitation pattern.",
                "direct_dependent_steps": [
                    23,
                    1
                ],
                "node": "Label the people $0,1,\\dots,1999$."
            },
            {
                "step_id": 25,
                "edge": "Using Step 2's $k=1000$ and Step 24's labeling, we define invitations such that user $i$ invites the next $k$ users modulo $n$: specifically, users $(i+1), (i+2), \\dots, (i+k) \\mod n$. This circular pattern ensures uniformity and leverages modular arithmetic to handle the cyclic nature of the labeling.",
                "direct_dependent_steps": [
                    2,
                    24
                ],
                "node": "Let person $i$ invite the $k$ people with labels $(i+1),(i+2),\\dots,(i+k)$ modulo $n$."
            },
            {
                "step_id": 26,
                "edge": "From Step 25's definition, each user $i$ invites exactly $k$ distinct users because the sequence $(i+1)$ to $(i+k)$ modulo $n$ (with $n=2000 > k=1000$) contains no duplicates. This satisfies the problem's constraint that every user sends precisely 1000 invitations.",
                "direct_dependent_steps": [
                    25
                ],
                "node": "Then person $i$ sends invitations to exactly $k$ people."
            },
            {
                "step_id": 27,
                "edge": "Applying Step 2's $k=1000$ to Step 25's invitation rule: for any pair differing by 1000 (e.g., $i$ and $i+1000 \\mod 2000$), user $i$ invites $i+1000$ (since $1000 \\leq k$), and user $i+1000$ invites $(i+1000)+1000 = i+2000 \\equiv i \\mod 2000$. Thus both invitations exist, forming a mutual pair.",
                "direct_dependent_steps": [
                    2,
                    25
                ],
                "node": "For any pair of people whose labels differ by $1000$, both invitations are present."
            },
            {
                "step_id": 28,
                "edge": "Step 1's $n=2000$ and Step 27's mutual pairs imply that pairs with label difference 1000 are distinct and non-overlapping. Since $n$ is even and 1000 is exactly half of $n$, there are $n/2$ such unordered pairs—each pair $(i, i+1000)$ for $i=0$ to $999$ covers all users without duplication.",
                "direct_dependent_steps": [
                    1,
                    27
                ],
                "node": "The number of unordered pairs with label difference $1000$ equals $\\frac{n}{2}$."
            },
            {
                "step_id": 29,
                "edge": "Substituting $n=2000$ (from Step 1) into Step 28's formula $n/2$ gives $2000/2 = 1000$. This arithmetic is straightforward: dividing an even number by 2 yields an integer, confirming exactly 1000 pairs have the required label difference for mutual invitations in this construction.",
                "direct_dependent_steps": [
                    1,
                    28
                ],
                "node": "Substituting $n=2000$ gives $\\frac{2000}{2} = 1000$ such pairs."
            },
            {
                "step_id": 30,
                "edge": "Building on Step 26 (each user sends exactly 1000 invitations) and Step 27 (difference-1000 pairs are mutual), we verify no other mutual pairs exist. For a pair with difference $d \\neq 1000$, if $d \\leq 1000$ then $i$ invites $j$ but $j$ only invites up to $j+1000 = i+d+1000$, which excludes $i$ unless $d=1000$ (since $d+1000 > 1000$ for $d>0$). Similarly, $d > 1000$ implies $i$ does not invite $j$ initially.",
                "direct_dependent_steps": [
                    26,
                    27
                ],
                "node": "No other unordered pair receives two invitations in this construction."
            },
            {
                "step_id": 31,
                "edge": "Combining Step 7's definition of $m$ (mutual pairs), Step 29's count of 1000 difference-1000 pairs, and Step 30's confirmation that no other mutual pairs exist, this construction achieves exactly $m = 1000$. Thus the lower bound from Step 22 is attainable.",
                "direct_dependent_steps": [
                    7,
                    29,
                    30
                ],
                "node": "Hence this construction achieves exactly $m = 1000$."
            },
            {
                "step_id": 32,
                "edge": "Step 22 established that $m \\geq 1000$ is necessary, and Step 31 demonstrated that $m = 1000$ is achievable. Therefore, the minimum number of friend pairs (mutual invitation pairs) is conclusively 1000, satisfying both the lower bound and feasibility requirements.",
                "direct_dependent_steps": [
                    22,
                    31
                ],
                "node": "Thus the minimum number of pairs of friends equals $1000$."
            },
            {
                "step_id": 33,
                "edge": "Based on Step 32's conclusion that the minimum friend pairs equal 1000, we present the final answer in the required boxed format. This value satisfies all problem constraints and represents the optimal solution derived through combinatorial reasoning and constructive proof.",
                "direct_dependent_steps": [
                    32
                ],
                "node": "The final answer is $\\boxed{1000}$."
            }
        ]
    }
]
