5948 - 相等序列

题目描述

A 有一个包含 N 个正整数的序列 A= { A_1,A_2,...,A_N }。小 A 每次可以花费 1 个金币执行以下任意一种操作:

选择序列中一个正整数 A_i1 \le i \le N),将 A_i 变为 A_i \times PP 为任意质数;

选择序列中一个正整数 A_i1 \le i \le N),将 A_i 变为 A_i/PP 为任意质数,要求 A_i 能整除 P

A 想请你帮他计算出令序列中所有整数都相同,最少需要花费多少金币。

输入

第一行一个正整数 N,含义如题面所示。

第二行包含 N 个正整数 A_1,A_2,...,A_N,代表序列 A

输出

输出一行,代表最少需要花费的金币数量。

样例

输入

5
10 6 35 105 42

输出

8
说明

数据范围

对于 60 %的测试点,保证 1 \le N,A_i \le 100

对于所有测试点,保证 1 \le N,A_i \le 10^5

来源

GESP 2025年12月认证 C++5级真题

标签
题目参数
时间限制 1 秒
内存限制 512 MB
提交次数 10
通过人数 6
金币数量 1 枚
难度 基础


上一题 下一题