[
    {
        "problem_id": 2190,
        "domain": [
            "Mathematics -> Discrete Mathematics -> Combinatorics",
            "Mathematics -> Algebra -> Intermediate Algebra -> Other"
        ],
        "difficulty": 4.0,
        "problem_text": "Let $N$ be the number of functions $f$ from $\\{1,2, \\ldots, 101\\} \\rightarrow\\{1,2, \\ldots, 101\\}$ such that $f^{101}(1)=2$. Find the remainder when $N$ is divided by 103.",
        "sample_id": 1,
        "final_answer": "43",
        "steps": [
            {
                "step_id": 1,
                "edge": "We introduce the notation $p=101$ to represent the size of the domain and codomain $\\{1,2,\\ldots,101\\}$, simplifying subsequent expressions and leveraging the problem's context where $101$ appears repeatedly as a key parameter.",
                "direct_dependent_steps": null,
                "node": "Let $p=101$ denote the size of the domain and codomain of $f$."
            },
            {
                "step_id": 2,
                "edge": "Building on Step 1's definition of $p$, we apply the fundamental counting principle for functions: each of the $p$ elements in the domain independently maps to any of the $p$ elements in the codomain, yielding $p \\times p \\times \\cdots \\times p$ ($p$ times) total functions, hence $p^p$.",
                "direct_dependent_steps": [
                    1
                ],
                "node": "The total number of functions from a $p$-element set to itself is $p^p$."
            },
            {
                "step_id": 3,
                "edge": "This step directly restates the problem's objective using the notation $p$ from Step 1, specifying that we seek functions $f$ where iterating $f$ exactly $p$ times starting from $1$ results in $2$, which defines the target count $N$.",
                "direct_dependent_steps": null,
                "node": "We seek the number of functions $f$ satisfying $f^p(1)=2$."
            },
            {
                "step_id": 4,
                "edge": "Relying on the symmetry inherent in the codomain $\\{1,2,\\ldots,p\\}$ (Step 1), where no element is distinguished by the problem's constraints, we assert that for a random function $f$, the value $f^p(1)$ is uniformly distributed across all $p$ elements. This probabilistic symmetry is critical for later partitioning.",
                "direct_dependent_steps": [
                    1
                ],
                "node": "By symmetry, the value of $f^p(1)$ is equally likely to be any of the $p$ elements."
            },
            {
                "step_id": 5,
                "edge": "Combining Step 2's total function count $p^p$, Step 3's target condition $f^p(1)=2$, and Step 4's symmetry principle (which implies all outcomes for $f^p(1)$ are equally probable except for structural constraints), we deduce that the count for $f^p(1)=2$ equals $(\\text{total functions} - \\text{functions with } f^p(1)=1)/(p-1)$. The subtraction isolates cases where $1$ maps to itself under iteration, and division by $p-1$ accounts for the symmetric distribution among the remaining $p-1$ elements including $2$.",
                "direct_dependent_steps": [
                    2,
                    3,
                    4
                ],
                "node": "Hence the number of functions with $f^p(1)=2$ equals the quotient of the total number of functions minus those with $f^p(1)=1$ by $p-1$."
            },
            {
                "step_id": 6,
                "edge": "To compute the count of functions where $f^p(1)=1$ (required for Step 5), we partition these functions based on the cycle length of $1$ in the functional graph of $f$. This structural decomposition is standard in combinatorics of iterated functions, as the behavior of $f^k(1)$ depends on the cycle containing $1$ and its preperiodic tail.",
                "direct_dependent_steps": [
                    5
                ],
                "node": "The functions with $f^p(1)=1$ can be partitioned according to the cycle length of $1$ under $f$."
            },
            {
                "step_id": 7,
                "edge": "Using Step 1's fact that $p=101$ is prime and Step 6's cycle-based partitioning, we note that the cycle length of $1$ must divide $p$ (since $f^p(1)=1$ implies the cycle length divides $p$). As $p$ is prime, the only possible cycle lengths are $1$ (fixed point) or $p$ (full cycle), eliminating intermediate cases.",
                "direct_dependent_steps": [
                    1,
                    6
                ],
                "node": "Since $p$ is prime, the cycle length of $1$ under $f$ is either $1$ or $p$."
            },
            {
                "step_id": 8,
                "edge": "Building on Step 7's cycle-length dichotomy, we analyze the case where $1$ has cycle length $1$. This requires $f(1)=1$ (a fixed point), and for the remaining $p-1$ elements, $f$ can map arbitrarily since their behavior does not affect $f^p(1)=1$ once $1$ is fixed. This cleanly separates the constraint on $1$ from the rest of the domain.",
                "direct_dependent_steps": [
                    7
                ],
                "node": "If the cycle length of $1$ is $1$, then $f(1)=1$ and $f$ can be arbitrary on the remaining $p-1$ elements."
            },
            {
                "step_id": 9,
                "edge": "Extending Step 8's scenario, with $f(1)=1$ fixed, each of the other $p-1$ domain elements independently chooses any of the $p$ codomain values. Applying the counting principle yields $p^{p-1}$ such functions, as confirmed by substituting the fixed-point constraint into the total function framework of Step 2.",
                "direct_dependent_steps": [
                    8
                ],
                "node": "There are $p^{p-1}$ functions satisfying $f(1)=1$."
            },
            {
                "step_id": 10,
                "edge": "Continuing Step 7's dichotomy, we examine the case where $1$ has cycle length $p$. Since the domain has exactly $p$ elements, this implies $1$ lies in a single cycle containing all elements—i.e., $f$ permutes the entire set cyclically with $1$ in a $p$-cycle. This restricts $f$ to being a cyclic permutation on the full set.",
                "direct_dependent_steps": [
                    7
                ],
                "node": "If the cycle length of $1$ is $p$, then $1$ lies in a $p$-cycle containing all $p$ elements."
            },
            {
                "step_id": 11,
                "edge": "For Step 10's $p$-cycle requirement, the number of cyclic orderings containing $1$ is $(p-1)!$. This follows from combinatorial permutation theory: fixing $1$'s position, the remaining $p-1$ elements can be arranged in $(p-1)!$ distinct cyclic orders to form a single $p$-cycle, as standard cycle-counting accounts for rotational symmetry.",
                "direct_dependent_steps": [
                    10
                ],
                "node": "There are $(p-1)!$ functions in which $1$ lies in a $p$-cycle."
            },
            {
                "step_id": 12,
                "edge": "Synthesizing Step 9's count for cycle length $1$ ($p^{p-1}$) and Step 11's count for cycle length $p$ ($(p-1)!$), we sum these disjoint cases to obtain the total number of functions satisfying $f^p(1)=1$. This union covers all possibilities per Step 7's prime-length constraint, ensuring no overlaps or omissions.",
                "direct_dependent_steps": [
                    9,
                    11
                ],
                "node": "Therefore the number of functions with $f^p(1)=1$ is $p^{p-1} + (p-1)!$."
            },
            {
                "step_id": 13,
                "edge": "Substituting Step 12's count for $f^p(1)=1$ into Step 5's quotient formula—which partitions the total functions (Step 2) by the symmetry-adjusted count for $f^p(1)=2$—we derive $N = \\frac{p^p - \\bigl(p^{p-1} + (p-1)!\\bigr)}{p-1}$. This expression isolates the desired count by excluding the asymmetric $f^p(1)=1$ case and distributing the remainder equally among the $p-1$ symmetric targets including $2$.",
                "direct_dependent_steps": [
                    5,
                    12
                ],
                "node": "Hence the number of functions with $f^p(1)=2$ is $\\frac{p^p - \\bigl(p^{p-1} + (p-1)!\\bigr)}{p-1}$."
            },
            {
                "step_id": 14,
                "edge": "Simplifying Step 13's quotient algebraically: the numerator $p^p - p^{p-1} = p^{p-1}(p-1)$, so dividing by $p-1$ gives $p^{p-1}$. The remaining term $-(p-1)!/(p-1) = -(p-2)!$ since $(p-1)! = (p-1)(p-2)!$. Thus the expression reduces cleanly to $p^{p-1} - (p-2)!$, a crucial simplification for modular computation.",
                "direct_dependent_steps": [
                    13
                ],
                "node": "Simplification of the quotient yields $p^{p-1} - (p-2)!$."
            },
            {
                "step_id": 15,
                "edge": "Confirming Step 14's simplified expression as the final form for $N$, we establish $N = p^{p-1} - (p-2)!$ by direct substitution. This compact formula, derived through combinatorial decomposition and algebraic reduction, is now primed for evaluation modulo $103$.",
                "direct_dependent_steps": [
                    14
                ],
                "node": "Therefore $N = p^{p-1} - (p-2)!$."
            },
            {
                "step_id": 16,
                "edge": "Given Step 15's expression for $N$, we initiate the modular computation required by the problem: finding $N \\mod 103$. Since $103$ is prime and distinct from $p=101$, we prepare to apply number-theoretic tools like Fermat's Little Theorem and Wilson's Theorem for efficient reduction.",
                "direct_dependent_steps": [
                    15
                ],
                "node": "We compute $N$ modulo $103$."
            },
            {
                "step_id": 17,
                "edge": "Applying Fermat's Little Theorem to Step 16's modulus $103$ (prime), we state that for any integer $a$ not divisible by $103$, $a^{102} \\equiv 1 \\pmod{103}$. This periodicity will simplify high-exponent terms like $101^{100}$ by reducing exponents modulo $102$.",
                "direct_dependent_steps": [
                    16
                ],
                "node": "Since $103$ is prime, Fermat's little theorem implies $a^{102}\\equiv1\\pmod{103}$ for $a\\not\\equiv0\\pmod{103}$."
            },
            {
                "step_id": 18,
                "edge": "Using Step 17's framework, we rewrite $101^{100} \\mod 103$ by noting $101 \\equiv -2 \\pmod{103}$ (since $103 - 2 = 101$). Thus $101^{100} \\equiv (-2)^{100} = 2^{100} \\pmod{103}$, leveraging congruence properties to convert a large base into a smaller equivalent.",
                "direct_dependent_steps": [
                    17
                ],
                "node": "Since $101\\equiv-2\\pmod{103}$, we have $101^{100}\\equiv(-2)^{100}\\pmod{103}$."
            },
            {
                "step_id": 19,
                "edge": "Reapplying Step 17's Fermat's Little Theorem specifically to base $2$, we obtain $2^{102} \\equiv 1 \\pmod{103}$. This identity allows exponent reduction for $2^{100}$ by expressing it as $2^{102 - 2} = 2^{-2}$, facilitating inverse-based simplification.",
                "direct_dependent_steps": [
                    17
                ],
                "node": "Fermat's little theorem also gives $2^{102}\\equiv1\\pmod{103}$."
            },
            {
                "step_id": 20,
                "edge": "From Step 19's $2^{102} \\equiv 1$, we isolate $2^{100}$ as $2^{102} \\cdot 2^{-2} \\equiv 1 \\cdot 2^{-2} \\pmod{103}$. Thus $2^{100} \\equiv 2^{-2} = (2^2)^{-1} = 4^{-1} \\pmod{103}$, converting the exponent problem into a modular inverse computation.",
                "direct_dependent_steps": [
                    19
                ],
                "node": "Hence $2^{100}\\equiv2^{-2}\\pmod{103}$."
            },
            {
                "step_id": 21,
                "edge": "By direct computation, the multiplicative inverse of $4$ modulo $103$ satisfies $4x \\equiv 1 \\pmod{103}$. Testing $x=26$: $4 \\times 26 = 104 \\equiv 1 \\pmod{103}$ (since $104 - 103 = 1$), confirming $26$ is the inverse. This standalone fact is essential for resolving $4^{-1}$.",
                "direct_dependent_steps": null,
                "node": "The multiplicative inverse of $4$ modulo $103$ is $26$."
            },
            {
                "step_id": 22,
                "edge": "Combining Step 18's $101^{100} \\equiv 2^{100}$, Step 20's $2^{100} \\equiv 4^{-1}$, and Step 21's $4^{-1} \\equiv 26$, we compute $101^{100} \\equiv 26 \\pmod{103}$. This consolidates the exponent term in $N$ into a concrete residue.",
                "direct_dependent_steps": [
                    18,
                    20,
                    21
                ],
                "node": "Therefore $101^{100}\\equiv26\\pmod{103}$."
            },
            {
                "step_id": 23,
                "edge": "Citing Wilson's Theorem for the prime modulus $103$, we state $102! \\equiv -1 \\pmod{103}$. This foundational factorial congruence will anchor our reduction of $(p-2)! = 99!$ modulo $103$.",
                "direct_dependent_steps": null,
                "node": "Wilson's theorem states that $102!\\equiv-1\\pmod{103}$."
            },
            {
                "step_id": 24,
                "edge": "Expanding $102!$ as a product for modular manipulation, we write $102! = 102 \\times 101 \\times 100 \\times 99!$. This factorization isolates $99!$, the term corresponding to $(p-2)!$ in Step 15 (since $p=101$), enabling its extraction via congruence.",
                "direct_dependent_steps": null,
                "node": "We write $102!=102\\cdot101\\cdot100\\cdot99!$."
            },
            {
                "step_id": 25,
                "edge": "Observing that $102 = 103 - 1$, we immediately have $102 \\equiv -1 \\pmod{103}$. This simple congruence converts a large factorial component into a manageable negative residue.",
                "direct_dependent_steps": null,
                "node": "We note that $102\\equiv-1\\pmod{103}$."
            },
            {
                "step_id": 26,
                "edge": "Similarly, $101 = 103 - 2$ implies $101 \\equiv -2 \\pmod{103}$. This equivalence, like Step 25's, streamlines the product in Step 24 by replacing large bases with small negatives.",
                "direct_dependent_steps": null,
                "node": "We note that $101\\equiv-2\\pmod{103}$."
            },
            {
                "step_id": 27,
                "edge": "Extending the pattern, $100 = 103 - 3$ gives $100 \\equiv -3 \\pmod{103}$. These sequential reductions (Steps 25–27) collectively transform the factorial product into a signed integer multiple of $99!$.",
                "direct_dependent_steps": null,
                "node": "We note that $100\\equiv-3\\pmod{103}$."
            },
            {
                "step_id": 28,
                "edge": "Substituting Step 23's Wilson congruence ($102! \\equiv -1$), Step 24's factorization, and Steps 25–27's equivalences ($102\\equiv-1$, $101\\equiv-2$, $100\\equiv-3$) into the product, we derive $(-1) \\times (-2) \\times (-3) \\times 99! \\equiv -1 \\pmod{103}$. The left side simplifies to $-6 \\times 99!$, directly linking to $99!$.",
                "direct_dependent_steps": [
                    23,
                    24,
                    25,
                    26,
                    27
                ],
                "node": "Therefore $(-1)\\cdot(-2)\\cdot(-3)\\cdot99!\\equiv-1\\pmod{103}$."
            },
            {
                "step_id": 29,
                "edge": "Simplifying Step 28's congruence $-6 \\times 99! \\equiv -1 \\pmod{103}$ by canceling the negative signs (multiplying both sides by $-1$), we obtain $6 \\times 99! \\equiv 1 \\pmod{103}$. This isolates $99!$ as a modular inverse problem.",
                "direct_dependent_steps": [
                    28
                ],
                "node": "Simplification yields $-6\\cdot99!\\equiv-1\\pmod{103}$."
            },
            {
                "step_id": 30,
                "edge": "Reaffirming Step 29's result $6 \\times 99! \\equiv 1 \\pmod{103}$, we explicitly state that $99!$ is the multiplicative inverse of $6$ modulo $103$. This equivalence is the critical bridge to computing $99! \\mod 103$.",
                "direct_dependent_steps": [
                    29
                ],
                "node": "Multiplying both sides by $-1$ yields $6\\cdot99!\\equiv1\\pmod{103}$."
            },
            {
                "step_id": 31,
                "edge": "Verifying $6 \\times 86 = 516$ and noting $516 \\div 103 = 5$ with remainder $516 - 5 \\times 103 = 516 - 515 = 1$, we confirm $6 \\times 86 \\equiv 1 \\pmod{103}$. Thus $86$ is the inverse of $6$, a standalone computational check essential for accuracy.",
                "direct_dependent_steps": null,
                "node": "The multiplicative inverse of $6$ modulo $103$ is $86$."
            },
            {
                "step_id": 32,
                "edge": "Using Step 30's equivalence $6 \\times 99! \\equiv 1$ and Step 31's inverse value $86$, we solve for $99! \\equiv 86 \\pmod{103}$. This resolves the factorial term in $N$'s expression to a concrete residue.",
                "direct_dependent_steps": [
                    30,
                    31
                ],
                "node": "Therefore $99!\\equiv86\\pmod{103}$."
            },
            {
                "step_id": 33,
                "edge": "Combining Step 22's $101^{100} \\equiv 26$ and Step 32's $99! \\equiv 86$ into Step 15's $N = p^{p-1} - (p-2)!$, we compute $N \\equiv 26 - 86 = -60 \\pmod{103}$. Converting to a positive residue: $-60 + 103 = 43$, yielding $N \\equiv 43 \\pmod{103}$.",
                "direct_dependent_steps": [
                    22,
                    32
                ],
                "node": "Substituting gives $N\\equiv26-86\\equiv-60\\equiv43\\pmod{103}$."
            },
            {
                "step_id": 34,
                "edge": "Finalizing Step 33's modular result, we box $43$ as the remainder when $N$ is divided by $103$, directly answering the problem's query with the computed congruence.",
                "direct_dependent_steps": [
                    33
                ],
                "node": "The final answer is \\boxed{43}"
            }
        ]
    }
]
