{
    "metadata": {
        "category": [],
        "competition": "bmo",
        "difficulty": 6.89,
        "level": "high_school",
        "source": "Balkan MO Shortlist",
        "url": "Private",
        "year": 2016
    },
    "problem": "Find all functions \\( f: \\mathbb{Z} \\rightarrow \\mathbb{Z} \\) for which \\( f(g(n)) - g(f(n)) \\) is independent of \\( n \\) for any \\( g: \\mathbb{Z} \\rightarrow \\mathbb{Z} \\).",
    "problem_id": "BMOSL_2016_8",
    "solutions": [
        {
            "author": "Human",
            "solution": "Solution. First observe that if $f(n)=n$, then $f(g(n))-g(f(n))=0$. Therefore the identity function satisfies the problem condition.\n\nIf there is $n_{0}$ with $f\\left(n_{0}\\right) \\neq n_{0}$, consider the characteristic function $g$ that is defined as $g\\left(f\\left(n_{0}\\right)\\right)=1$ and $g(n)=0$ for $n \\neq f\\left(n_{0}\\right)$. In this case, let $n \\neq f\\left(n_{0}\\right)$ be arbirtrary. One has $f(g(n))-g(f(n))=$ $f\\left(g\\left(n_{0}\\right)\\right)-g\\left(f\\left(n_{0}\\right)\\right) \\Rightarrow f(0)-g(f(n))=f(0)-g\\left(f\\left(n_{0}\\right)\\right) \\Rightarrow g(f(n))=1 \\Rightarrow f(n)=f\\left(n_{0}\\right)$.\n\nNow, consider the very similar function $g$ that is defined as $g\\left(f\\left(n_{0}\\right)\\right)=a$ and $g(n)=b$ for $n \\neq f\\left(n_{0}\\right)$, where $a, b$ are integers with $a \\neq b \\neq f\\left(n_{0}\\right)$. We have chosen $a, b$ so as to ensure that $f(a)=f\\left(n_{0}\\right)=f(b)$. Now, we find that $f\\left(g\\left(f\\left(n_{0}\\right)\\right)\\right)-g\\left(f\\left(f\\left(n_{0}\\right)\\right)\\right)=f\\left(g\\left(n_{0}\\right)\\right)-g\\left(f\\left(n_{0}\\right)\\right) \\Rightarrow f(a)-g\\left(f\\left(f\\left(n_{0}\\right)\\right)\\right)=f(b)-$ $g\\left(f\\left(n_{0}\\right)\\right) \\Rightarrow g\\left(f\\left(f\\left(n_{0}\\right)\\right)\\right)=g\\left(f\\left(n_{0}\\right)\\right)=a \\Rightarrow f\\left(f\\left(n_{0}\\right)\\right)=f\\left(n_{0}\\right)$.\n\nIn summary, $f(n)=f\\left(n_{0}\\right)$ for any $n \\neq f\\left(n_{0}\\right)$ and $f\\left(f\\left(n_{0}\\right)\\right)=f\\left(n_{0}\\right)$. Therefore $f$ is a constant function. Let us now see that a constant function indeed satisfies the problem condition: If $f(n)=c$ for all $n, f(g(n))-g(f(n))=c-g(c)$ is independent of $n$.\n\nThe answers are the identity function $f(n)=n$ and the constant functions $f(n)=c$.",
            "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"
}