[
    {
        "problem_id": 2949,
        "domain": [
            "Mathematics -> Algebra -> Algebra -> Algebraic Expressions"
        ],
        "difficulty": 6.0,
        "problem_text": "How many functions $f:\\{1,2, \\ldots, 2013\\} \\rightarrow\\{1,2, \\ldots, 2013\\}$ satisfy $f(j)<f(i)+j-i$ for all integers $i, j$ such that $1 \\leq i<j \\leq 2013$ ?",
        "sample_id": 1,
        "final_answer": "\\boxed{\\binom{4025}{2013}}",
        "steps": [
            {
                "step_id": 1,
                "edge": "We begin by establishing the fundamental setup from the problem statement: f is defined as a function with domain and codomain both being the set {1, 2, ..., 2013}. This step introduces the core object of study without dependencies, as it directly states the initial conditions given in the problem.",
                "direct_dependent_steps": null,
                "node": "Let f be a function from the set {1,2,...,2013} to itself."
            },
            {
                "step_id": 2,
                "edge": "The problem imposes a specific constraint on f that must hold for all pairs i < j, which we record verbatim from the problem statement. This condition serves as the critical inequality governing valid functions, and since it is given directly in the problem, no prior steps support it.",
                "direct_dependent_steps": null,
                "node": "The function f must satisfy the inequality f(j) < f(i) + j − i for all integers i, j with 1 ≤ i < j ≤ 2013."
            },
            {
                "step_id": 3,
                "edge": "Starting from the inequality in Step 2 (f(j) < f(i) + j - i), we perform algebraic rearrangement by subtracting j from both sides and then adding i to both sides, yielding f(j) - j < f(i) - i. This transformation simplifies the condition by isolating the terms involving each variable separately, which is a standard algebraic technique to reveal underlying structure without changing the inequality's meaning.",
                "direct_dependent_steps": [
                    2
                ],
                "node": "The inequality f(j) < f(i) + j − i is algebraically equivalent to f(j) − j < f(i) − i for all 1 ≤ i < j ≤ 2013."
            },
            {
                "step_id": 4,
                "edge": "To leverage the simplified inequality from Step 3, we define a new function g(i) = f(i) - i. This substitution is a strategic move to absorb the linear terms into a single expression, transforming the problem into one about the behavior of g. The definition directly follows from recognizing the pattern in Step 3's rearranged inequality.",
                "direct_dependent_steps": [
                    3
                ],
                "node": "Define a new function g on {1,2,...,2013} by setting g(i) = f(i) − i for each i."
            },
            {
                "step_id": 5,
                "edge": "Applying the definition of g from Step 4 to the inequality in Step 3, we substitute g(i) for f(i) - i and g(j) for f(j) - j, immediately converting f(j) - j < f(i) - i into g(j) < g(i). This substitution streamlines the condition by eliminating the original variables' complexity, showing that the constraint now solely governs the relative values of g at different points.",
                "direct_dependent_steps": [
                    3,
                    4
                ],
                "node": "Under this definition, the inequality f(j) − j < f(i) − i becomes g(j) < g(i) for all 1 ≤ i < j ≤ 2013."
            },
            {
                "step_id": 6,
                "edge": "Since Step 1 specifies that f maps to {1, 2, ..., 2013}, we explicitly state the codomain constraint: for every input i, f(i) must be an integer between 1 and 2013 inclusive. This fundamental property of f, derived directly from the problem's domain definition, provides essential bounds for subsequent calculations.",
                "direct_dependent_steps": [
                    1
                ],
                "node": "Since f maps into {1,2,...,2013}, each value f(i) satisfies 1 ≤ f(i) ≤ 2013."
            },
            {
                "step_id": 7,
                "edge": "Using the definition of g from Step 4 (g(i) = f(i) - i) and the bounds on f(i) from Step 6 (1 ≤ f(i) ≤ 2013), we derive corresponding bounds for g(i) by subtracting i throughout the inequality: 1 - i ≤ f(i) - i ≤ 2013 - i. This preserves the inequality direction and establishes the range of possible values for each g(i), crucial for determining g's feasible outputs.",
                "direct_dependent_steps": [
                    4,
                    6
                ],
                "node": "For each i, the inequalities 1 ≤ f(i) ≤ 2013 imply 1 − i ≤ g(i) ≤ 2013 − i."
            },
            {
                "step_id": 8,
                "edge": "The condition g(j) < g(i) for all i < j (from Step 5) directly implies that as the index increases, g's value decreases. Specifically, for consecutive indices or any i < j, g(j) is strictly less than g(i), meaning the sequence g(1), g(2), ..., g(2013) must be strictly decreasing. This rephrasing transforms the pairwise inequality into a clear sequence property essential for combinatorial counting.",
                "direct_dependent_steps": [
                    5
                ],
                "node": "The inequality g(j) < g(i) for i < j indicates that the sequence g(1), g(2), ..., g(2013) is strictly decreasing."
            },
            {
                "step_id": 9,
                "edge": "Because the sequence is strictly decreasing (Step 8), the smallest value must occur at the largest index i = 2013. Using the lower bound from Step 7 (g(i) ≥ 1 - i), we evaluate at i = 2013: 1 - 2013 = -2012. Since g takes integer values (as f and i are integers), this is achievable and represents the absolute minimum possible value for any g(i).",
                "direct_dependent_steps": [
                    7,
                    8
                ],
                "node": "The minimum possible value of g(i) occurs at i = 2013 and equals 1 − 2013 = −2012."
            },
            {
                "step_id": 10,
                "edge": "Similarly, for the strictly decreasing sequence (Step 8), the largest value must occur at the smallest index i = 1. Applying the upper bound from Step 7 (g(i) ≤ 2013 - i) at i = 1 gives 2013 - 1 = 2012. This integer value is attainable and defines the maximum possible value across all g(i), completing the extreme value characterization.",
                "direct_dependent_steps": [
                    7,
                    8
                ],
                "node": "The maximum possible value of g(i) occurs at i = 1 and equals 2013 − 1 = 2012."
            },
            {
                "step_id": 11,
                "edge": "Combining the minimum value -2012 from Step 9 and maximum value 2012 from Step 10, and noting that g(i) must be integer-valued (since f(i) and i are integers), the possible values for g(i) span all integers from -2012 to 2012 inclusive. This interval forms a contiguous set of integers, which we will use to determine the total number of candidate values for the sequence.",
                "direct_dependent_steps": [
                    9,
                    10
                ],
                "node": "Therefore the range of possible values for g(i) is the set of integers from −2012 to 2012 inclusive."
            },
            {
                "step_id": 12,
                "edge": "Given that g must be strictly decreasing (Step 8) and its values must lie within the integer set from -2012 to 2012 (Step 11), constructing such a sequence of length 2013 is equivalent to selecting any 2013 distinct integers from this set and arranging them in decreasing order. Since a strictly decreasing sequence is uniquely determined by its set of values (with only one valid ordering), the counting problem reduces to combinations rather than permutations. The total number of integers in the range is (2012) - (-2012) + 1 = 4025, as verified by the inclusive count formula.",
                "direct_dependent_steps": [
                    8,
                    11
                ],
                "node": "Constructing g as a strictly decreasing sequence of length 2013 from the 4025 available integers between −2012 and 2012 is equivalent to choosing 2013 distinct integers from that set and arranging them in decreasing order."
            },
            {
                "step_id": 13,
                "edge": "The number of ways to choose 2013 distinct integers from a set of 4025 available integers (as established in Step 12) is precisely given by the binomial coefficient \\(\\binom{4025}{2013}\\). This combinatorial quantity counts unordered selections, matching our requirement since the decreasing arrangement is forced once the set is chosen. No further arithmetic is needed as the binomial coefficient directly represents the solution count.",
                "direct_dependent_steps": [
                    12
                ],
                "node": "The number of ways to choose 2013 distinct integers from a set of 4025 integers is the binomial coefficient \\(\\binom{4025}{2013}\\)."
            },
            {
                "step_id": 14,
                "edge": "The binomial coefficient \\(\\binom{4025}{2013}\\) from Step 13 represents the total number of valid functions f satisfying the original condition, as it enumerates all possible strictly decreasing sequences for g, which are in one-to-one correspondence with valid f via the transformation in Step 4. Thus, we present this as the final answer in the required boxed format.",
                "direct_dependent_steps": [
                    13
                ],
                "node": "The final answer is \\boxed{\\binom{4025}{2013}}."
            }
        ]
    }
]
