{
    "metadata": {
        "category": [],
        "competition": "bmo",
        "difficulty": 6.97,
        "level": "high_school",
        "source": "Balkan MO Shortlist",
        "url": "Private",
        "year": 2018
    },
    "problem": "Find all functions \\( f: \\mathbb{N} \\rightarrow \\mathbb{N} \\) such that\n\n\\[\nn!+f(m)!\\mid f(n)!+f(m!)\n\\]\n\nfor all \\( m, n \\in \\mathbb{N} \\).",
    "problem_id": "BMOSL_2018_17",
    "solutions": [
        {
            "author": "Human",
            "solution": "Answer: $f(n)=n$ for all $n \\in \\mathbb{N}$.\nTaking $m=n=1$ in $(*)$ yields $1+f(1)!\\mid f(1)!+f(1)$ and hence $1+f(1)!\\mid f(1)-1$. Since $|f(1)-1|<f(1)!+1$, this implies $f(1)=1$.\nFor $m=1$ in $(*)$ we have $n!+1 \\mid f(n)!+1$, which implies $n!\\leqslant f(n)$ !, i.e. $f(n) \\geqslant n$.\nOn the other hand, taking $(m, n)=(1, p-1)$ for any prime number $p$ and using Wilson's theorem we obtain $p|(p-1)!+1| f(p-1)!+1$, implying $f(p-1)<p$. Therefore\n\n$$\nf(p-1)=p-1\n$$\n\nNext, fix a positive integer $m$. For any prime number $p$, setting $n=p-1$ in (*) yields $(p-1)!+f(m)!\\mid(p-1)!+f(m!)$, and hence\n\n$$\n(p-1)!+f(m)!\\mid f(m!)-f(m)!\\text { for all prime numbers } p\n$$\n\nThis implies $f(m!)=f(m)$ ! for all $m \\in \\mathbb{N}$, so $(*)$ can be rewritten as $n!+f(m)!\\mid$ $f(n)!+f(m)$ !. This implies\n\n$$\nn!+f(m)!\\mid f(n)!-n!\\text { for all } n, m \\in \\mathbb{N}\n$$\n\nFixing $n \\in \\mathbb{N}$ and taking $m \\in \\mathbb{N}$ large enough, we conclude that $f(n)$ ! $=n$ !, i.e. $f(n)=n$, for all $n \\in \\mathbb{N}$.\nOne readily checks that the identity function satisfies the conditions of the problem.",
            "images": {}
        }
    ],
    "grading_scheme": [
        {
            "part_id": 1,
            "title": "Correctness",
            "description": "<p>A solution should be considered correct even if it would earn 5+/7 points in a full grading. Examples of small penalties worth 1 point are if the solution: <ul><li>Makes a small computational mistake that can be easily fixed</li><li>Misses an edge case which can be easily proven/disproven</li><li>Skips over a step that follows without much reasoning or manual work</li></ul> A solution should be marked as incorrect if: <ul><li>It marks a step as trivial, if it is not immediately obvious why this would be the case</li><li>It omits algebra-heavy computational steps, regardless of whether or not it has outlined the methodology</li><li>Generalizes over a pattern without rigorously describing the pattern, or without proving any relevant properties.</li><li>It cites a non-existing or unpopular source/Theorem, which cannot be immediately found from searching for it online. Thus, any theorems that can be immediately found and have a Wikipedia article are allowed.</li></ul> The model has been specifically told that it should not skip steps or mark them as trivial. Any violation of this rule should be considered by assuming the model does not know how to derive the &quot;trivial&quot; step</p>",
            "points": 1
        }
    ],
    "points": 1,
    "date_added": "2025-06-02 21:45:56"
}