[WC2021] 斐波那契
题目描述
众所周知,小葱同学擅长计算,尤其擅长计算组合数。但是对组合数有了充分研究的小葱同学对组合数失去了兴趣,而开始研究数列。
我们定义 $F_0 = a$,$F_1 = b$,$F_i = (F_{i-1} + F_{i-2}) \bmod m$($i \ge 2$)。
现在给定 $n$ 组询问,对于每组询问请找到一个最小的整数 $p$,使得 $F_p = 0$。
输入输出格式
输入格式
第一行两个整数 $n, m$,代表询问的组数和每组计算中的模数。
接下来 $n$ 行每行两个整数 $a, b$,代表一组询问中 $F_0$ 和 $F_1$ 的值。
输出格式
对于每组询问,输出一行一个整数 $p$ 代表答案。如果这样的 $p$ 不存在,输出 `-1`。
输入输出样例
输入样例 #1
4 5
0 1
1 2
2 3
3 4
输出样例 #1
0
3
2
-1
输入样例 #2
1 6
4 4
输出样例 #2
3
输入样例 #3
见附件中的 fib/fib3.in
输出样例 #3
见附件中的 fib/fib3.ans
输入样例 #4
见附件中的 fib/fib4.in
输出样例 #4
见附件中的 fib/fib4.ans
说明
**【数据范围】**
对于所有测试点:$1 \le n, m \le {10}^5$,$0 \le a, b < m$。
每个测试点的具体限制见下表:
| 测试点编号 | $n, m \le$ | 特殊限制 |
|:-:|:-:|:-:|
| $1 \sim 2$ | $1000$ | 无 |
| $3 \sim 4$ | ${10}^5$ | $m$ 是质数 |
| $5 \sim 6$ | ${10}^5$ | $m = p_1 p_2 \cdots p_k$,其中 $p_i$ 是两两不同的质数 |
| $7 \sim 10$ | ${10}^5$ | 无 |