2847. 给定数字乘积的最小数字 🔒
题目描述
给定一个 正 整数 n
,返回一个字符串,表示使其各位数字的乘积等于 n
的 最小正整数,如果不存在这样的数字,则返回 "-1"
。
示例 1:
输入:n = 105 输出:"357" 解释:3 * 5 * 7 = 105。可以证明,357 是各位数字的乘积等于 105 的最小数字。因此答案为 "357"。
示例 2:
输入:n = 7 输出:"7" 解释:由于 7 只有一位数字,其各位数字的乘积为 7。由于数字 1 到 6 的乘积分别为 1 到 6,所以答案为 "7"。可以证明 7 是乘积等于 7 的最小数字。
示例 3:
输入:n = 44 输出:"-1" 解释:可以证明,没有数字的各位数字乘积等于 44。因此答案为 "-1"。
提示:
1 <= n <= 1018
解法
方法一:质因数分解 + 贪心
我们考虑对数字 $n$ 进行质因数分解,如果 $n$ 的质因数中存在大于 $9$ 的质数,那么一定无法找到符合条件的数字,因为大于 $9$ 的质数无法通过 $1$ 到 $9$ 的数字相乘得到,例如 $11$ 无法通过 $1$ 到 $9$ 的数字相乘得到,因此我们只需要考虑 $n$ 的质因数中是否存在大于 $9$ 的质数即可,如果存在,直接返回 $-1$。
否则,如果质因数中包含 $7$ 和 $5$,那么数字 $n$ 首先可以拆分为若干个 $7$ 和 $5$,两个数字 $3$ 可以合成一个数字 $9$,三个数字 $2$ 可以合成一个数字 $8$,数字 $2$ 和数字 $3$ 可以合成一个数字 $6$,因此我们只需要将数字拆分为 $[2,..9]$ 的数字即可,我们可以使用贪心的方法,优先拆分出数字 $9$,然后拆分出数字 $8$,依次类推。
时间复杂度 $O(\log n)$,空间复杂度 $O(1)$。
1 2 3 4 5 6 7 8 9 10 11 |
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 |
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 |
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 |
|