#L4041. 「SNOI2024」平方数

    ID: 3413 传统题 1000ms 256MiB 尝试: 2 已通过: 1 难度: 10 上传者: 标签>数据结构前缀和字符串哈希和哈希表数论其他位运算

「SNOI2024」平方数

题目描述

你有一个正整数序列 a1,a2,,ana_1, a_2, \dots, a_n。请问有多少个区间的乘积是完全平方数。也就是有多少对 (l,r)(l, r) (1lrn)(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 个即可。


样例 1

输入

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

样例 2

输入

3
999999999999999956000000000000000363
999999999999999844000000000000004059
999999999999999866000000000000001353

输出

1
1 3

这三个数为 10181110^{18} - 11, 10183310^{18} - 33, 101812310^{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