loj#P4041. 「SNOI2024」平方数

「SNOI2024」平方数

题目描述

你有一个正整数序列 a1,a2,,ana_1, a_2, \dots, a_n。请问有多少个区间的乘积是完全平方数。也就是有多少对 (l,r)(1lrn)(l, r) (1\leq l\leq r \leq n),满足 i=lrai\prod_{i=l}^r a_i 是完全平方数。

输入格式

第一行一个整数 nn 表示数字个数。

接下来一行,每行 nn 个数,表示 a1,a2,,ana_1, a_2, \dots, a_n

输出格式

输出一个整数,表示有多少对区间的乘积是完全平方数。

接下来按照字典序输出这些区间,也就是按照 ll 从小到大输出,如果有多个 ll 相同的区间,按照 rr 从小到大输出。如果区间个数超过 10510^5 个,输出前 10510^5 个即可。

10
1 2 3 4 6 8 9 12 16 18

12
1 1
1 5
2 5
3 6
3 7
4 4
4 8
4 9
5 8
5 9
7 7
9 9

3
999999999999999956000000000000000363
999999999999999844000000000000004059
999999999999999866000000000000001353

1
1 3

这三个数为 101811,101833,101812310^{18} - 11, 10^{18} - 33, 10^{18} - 123 两两相乘。

数据范围与提示

对于所有的数据,保证 1n3×1051\leq n \leq 3\times 10^5, 1ai10361 \leq a_i\leq 10^{36}

具体如下:

测试点编号 nn\leq aia_i\leq
131\sim3 10001000 10410^4
464\sim6 10510^5 10610^6
7107\sim10 100100 103610^{36}
111411\sim14 10001000
151715\sim17 10510^5
182018\sim20 3×1053\times 10^5