AT_abc254_h [ABC254Ex] Multiply or Divide by 2
题目描述
给定两个由 N 个非负整数组成的多重集 A={a1,…,aN} 和 B={b1,…,bN}。
你可以以任意顺序、任意次数进行以下操作:
- 从 A 中选择一个非负整数 x,将 A 中的一个 x 删除,并加入一个 2x。
- 从 A 中选择一个非负整数 x,将 A 中的一个 x 删除,并加入一个 ⌊2x⌋。(⌊x⌋ 表示不超过 x 的最大整数)
你的目标是使 A 和 B 作为多重集完全相同。
请判断是否可以达成目标,如果可以,请求出所需操作次数的最小值。
输入格式
输入按以下格式从标准输入读入。
N a1 … aN b1 … bN
输出格式
如果可以达成目标,输出所需操作次数的最小值;否则输出 −1。
输入输出样例 #1
输入 #1
3
3 4 5
2 4 6
输出 #1
2
输入输出样例 #2
输入 #2
1
0
1
输出 #2
-1
说明/提示
限制条件
- 1≤N≤105
- 0≤a1≤…≤aN≤109
- 0≤b1≤…≤bN≤109
- 输入均为整数
样例解释 1
可以通过如下两步操作达成目标:
- 选择 x=3,将 A 中的 x (=3) 删除,加入 2x (=6)。此时 A={4,5,6}。
- 选择 x=5,将 A 中的 x (=5) 删除,加入 ⌊2x⌋ (=2)。此时 A={2,4,6}。
样例解释 2
无法将 {0} 变为 {1}。
由 ChatGPT 4.1 翻译