CF1614D2 Divan and Kostomuksha (hard version)
题目描述
这是该问题的困难版本。唯一的区别在于 $a_i$ 的最大值。
在 Kostomuksha,Divan 发现了一个由正整数组成的数组 $a$。现在他想要重新排列 $a$ 的元素,使下列函数的值最大:
$$ \sum_{i=1}^n \operatorname{gcd}(a_1,\, a_2,\, \dots,\, a_i), $$
其中 $\operatorname{gcd}(x_1, x_2, \ldots, x_k)$ 表示整数 $x_1, x_2, \ldots, x_k$ 的[最大公约数](https://en.wikipedia.org/wiki/Greatest_common_divisor),且对于任意整数 $x$,有 $\operatorname{gcd}(x) = x$。
重新排列数组元素意味着可以任意改变数组中元素的顺序,也可以保持初始顺序不变。
当然,Divan 能解决这个问题。但他觉得这个问题很有趣,所以决定把它分享给你。
输入格式
第一行包含一个整数 $n$($1 \leq n \leq 10^5$)——数组 $a$ 的大小。
第二行包含 $n$ 个整数 $a_1,\, a_2,\, \dots,\, a_n$($1 \le a_i \le 2 \cdot 10^7$)——数组 $a$。
输出格式
输出通过重新排列数组 $a$ 后可以获得的该函数的最大值。
说明/提示
在第一个样例中,最优的排列方式是 $[6,\, 2,\, 2,\, 2,\, 3,\, 1]$:
$\operatorname{gcd}(a_1) + \operatorname{gcd}(a_1,\, a_2) + \operatorname{gcd}(a_1,\, a_2,\, a_3) + \operatorname{gcd}(a_1,\, a_2,\, a_3,\, a_4) + \operatorname{gcd}(a_1,\, a_2,\, a_3,\, a_4,\, a_5) + \operatorname{gcd}(a_1,\, a_2,\, a_3,\, a_4,\, a_5,\, a_6) = 6 + 2 + 2 + 2 + 1 + 1 = 14$。
可以证明无法得到更优的答案。
在第二个样例中,最优的排列方式是 $[100,\, 10,\, 10,\, 5,\, 1,\, 3,\, 3,\, 7,\, 42,\, 54]$。
由 ChatGPT 4.1 翻译