#aBC276Did336. [ABC276D] Divide by 2 or 3

[ABC276D] Divide by 2 or 3

AT_abc276_d [ABC276D] Divide by 2 or 3

题目描述

给定一个正整数序列 A=(a1,a2,,aN)A=(a_1,a_2,\ldots,a_N)
你可以重复执行以下两种操作中的任意一种,次数不限(可以为 00 次):

  • 选择一个满足 1iN1 \leq i \leq Naia_i22 的倍数的整数 ii,将 aia_i 替换为 ai2\frac{a_i}{2}
  • 选择一个满足 1iN1 \leq i \leq Naia_i33 的倍数的整数 ii,将 aia_i 替换为 ai3\frac{a_i}{3}

你的目标是使 AA 满足 a1=a2==aNa_1=a_2=\ldots=a_N
请你求出实现目标所需操作次数的最小值。如果无论如何都无法实现目标,请输出 1-1

输入格式

输入按以下格式从标准输入读入。

NN a1a_1 a2a_2 \ldots aNa_N

输出格式

请输出答案。

输入输出样例 #1

输入 #1

3
1 4 3

输出 #1

3

输入输出样例 #2

输入 #2

3
2 7 6

输出 #2

-1

输入输出样例 #3

输入 #3

6
1 1 1 1 1 1

输出 #3

0

说明/提示

限制条件

  • 2N10002 \leq N \leq 1000
  • 1ai1091 \leq a_i \leq 10^9
  • 输入均为整数

样例解释 1

可以按如下方式操作,最少 33 次即可达成目标:

  • 选择 aia_i22 的倍数的 i=2i=2,将 a2a_2 替换为 a22\frac{a_2}{2},此时 A=(1,2,3)A=(1,2,3)
  • 选择 aia_i22 的倍数的 i=2i=2,将 a2a_2 替换为 a22\frac{a_2}{2},此时 A=(1,1,3)A=(1,1,3)
  • 选择 aia_i33 的倍数的 i=3i=3,将 a3a_3 替换为 a33\frac{a_3}{3},此时 A=(1,1,1)A=(1,1,1)

样例解释 2

无论如何操作都无法达成目标。

由 ChatGPT 4.1 翻译