codeforces#P1570D. Reachable Numbers
Reachable Numbers
Description
Let's denote a function $f(x)$ in such a way: we add $1$ to $x$, then, while there is at least one trailing zero in the resulting number, we remove that zero. For example,
- $f(599) = 6$: $599 + 1 = 600 \rightarrow 60 \rightarrow 6$;
- $f(7) = 8$: $7 + 1 = 8$;
- $f(9) = 1$: $9 + 1 = 10 \rightarrow 1$;
- $f(10099) = 101$: $10099 + 1 = 10100 \rightarrow 1010 \rightarrow 101$.
We say that some number $y$ is reachable from $x$ if we can apply function $f$ to $x$ some (possibly zero) times so that we get $y$ as a result. For example, $102$ is reachable from $10098$ because $f(f(f(10098))) = f(f(10099)) = f(101) = 102$; and any number is reachable from itself.
You are given a number $n$; your task is to count how many different numbers are reachable from $n$.
The first line contains one integer $n$ ($1 \le n \le 10^9$).
Print one integer: the number of different numbers that are reachable from $n$.
Input
The first line contains one integer $n$ ($1 \le n \le 10^9$).
Output
Print one integer: the number of different numbers that are reachable from $n$.
Samples
1098
20
10
19
Note
The numbers that are reachable from $1098$ are:
$1, 2, 3, 4, 5, 6, 7, 8, 9, 11, 12, 13, 14, 15, 16, 17, 18, 19, 1098, 1099$.