#P3464. 「WC2021」斐波那契

「WC2021」斐波那契

题目描述

众所周知,小葱同学擅长计算,尤其擅长计算组合数。但是对组合数有了充分研究的小葱同学对组合数失去了兴趣,而开始研究数列。

我们定义 F0=aF_0 = aF1=bF_1 = bFi=(Fi1+Fi2)modmF_i = (F_{i-1} + F_{i-2}) \bmod mi2i \ge 2)。

现在给定 nn 组询问,对于每组询问请找到一个最小的整数 pp,使得 Fp=0F_p = 0

输入格式

第一行两个整数 n,mn, m,代表询问的组数和每组计算中的模数。

接下来 nn 行每行两个整数 a,ba, b,代表一组询问中 F0F_0F1F_1 的值。

输出格式

对于每组询问,输出一行一个整数 pp 代表答案。如果这样的 pp 不存在,输出 -1

4 5
0 1
1 2
2 3
3 4

0
3
2
-1

1 6
4 4

3

样例 3

见附加文件中的 fib3.infib3.ans

样例 4

见附加文件中的 fib4.infib4.ans

数据范围与提示

对于所有测试点:1n,m1051 \le n, m \le {10}^50a,b<m0 \le a, b < m

每个测试点的具体限制见下表:

测试点编号 n,mn, m \le 特殊限制
121 \sim 2 10001000
343 \sim 4 105{10}^5 mm 是质数
565 \sim 6 m=p1p2pkm = p_1 p_2 \cdots p_k,其中 pip_i 是两两不同的质数
7107 \sim 10