CF1681D Required Length
题目描述
给定两个整数 $n$ 和 $x$。你可以对整数 $x$ 执行若干次操作。
每次操作如下:选择 $x$ 的十进制表示中至少出现一次的任意一个数字 $y$,然后将 $x$ 替换为 $x \cdot y$。
你希望使 $x$ 的十进制表示(不含前导零)的长度变为 $n$。请问最少需要多少次操作才能达到目标?如果无法实现,请输出 $-1$。
输入格式
输入仅一行,包含两个整数 $n$ 和 $x$($2 \le n \le 19$;$1 \le x < 10^{n-1}$)。
输出格式
输出一个整数,表示使 $x$ 的十进制表示长度变为 $n$ 所需的最少操作次数。如果无法实现,输出 $-1$。
说明/提示
在第二个样例中,可以通过以下操作序列实现目标:
1. 用 $2$ 乘以 $x$,此时 $x = 2 \cdot 2 = 4$;
2. 用 $4$ 乘以 $x$,此时 $x = 4 \cdot 4 = 16$;
3. 用 $6$ 乘以 $x$,此时 $x = 16 \cdot 6 = 96$;
4. 用 $9$ 乘以 $x$,此时 $x = 96 \cdot 9 = 864$。
由 ChatGPT 4.1 翻译