[USACO21FEB] Stone Game G

题目描述

Bessie 和 Elsie 正在用 $N$($1\le N\le 10^5$)堆石子进行一个游戏,其中对于每个 $1\le i\le N$,第 $i$ 堆石子有 $a_i$ 个石子($1\le a_i\le 10^6$)。两头奶牛交替行动,Bessie 先手。 - 首先,Bessie 选择某个正整数 $s_1$ 并从至少包含 $s_1$ 个石子的某堆石子中取走 $s_1$ 个石子。 - 然后 Elsie 选择某个正整数 $s_2$,使得 $s_1$ 整除 $s_2$,并从至少包含 $s_2$ 个石子的某堆石子中取走 $s_2$ 个石子。 - 然后 Bessie 选择某个正整数 $s_3$,使得 $s_2$ 整除 $s_3$,并从至少包含 $s_3$ 个石子的某堆石子中取走 $s_3$ 个石子,以此类推。 - 总的来说,第 $i$ 回合中取走的石子数量 $s_i$ 必须整除 $s_{i+1}$。 第一个无法在其回合中取走石子的奶牛为失败者。 计算可以令 Bessie 必胜(表示存在一种策略,无论 Elsie 如何行动,Bessie 均可获胜)的第一回合取石子的方法数。如果两种取石子的方法中取的石子数量不同或者取的石子堆不同,则认为是两种不同的取石子的方法。

输入输出格式

输入格式


输入的第一行包含 $N$。 第二行包含 $N$ 个空格分隔的整数 $a_1,\ldots,a_N$。

输出格式


输出可以令 Bessie 必胜(表示存在一种策略,无论 Elsie 如何行动,Bessie 均可获胜)的第一回合取石子的方法数。 注意这个问题涉及到的整数大小可能需要使用 $64$ 位整数型存储(例如,C/C++ 中的 long long)。

输入输出样例

输入样例 #1

1
7

输出样例 #1

4

输入样例 #2

6
3 2 3 2 3 1

输出样例 #2

8

说明

#### 样例 1 解释: 当 Bessie 从唯一的一堆石子中取走 $4$、$5$、$6$ 或 $7$ 个石子时可以获胜。此时游戏会立刻结束。 #### 样例 2 解释: 当 Bessie 从任意一堆中取走 $2$ 或 $3$ 个石子时可以获胜。此后两头奶牛会交替取走相同数量的石子,而 Bessie 执行了最后一次操作。 #### 测试点性质: - 对于另外 $15\%$ 的数据,满足 $N=2$。 - 对于另外 $25\%$ 的数据,满足 $N,a_i\le 100$。 - 对于另外 $50\%$ 的数据,没有额外限制。 供题:Benjamin Qi