data:image/s3,"s3://crabby-images/7a93c/7a93ce132a76f329feb30b999fd4b1b3519cca57" alt=""
The first line is an positive integer T . (1<=T<= 10^3) indicates the number of test cases. In the next T lines, there are three positive integer n, m, p (1<= n,m,p<=10^9) at each line.css
1
1 2 3
1
gcd(1 + Sn, 1 + Sm) = gcd(fib(n + 2), fib(m + 2)) = fib(gcd(n + 2, m + 2)).markdown
#include <stdio.h> int gcd(int a, int b) { return b ? gcd(b, a % b) : a; } int main() { int t, n, m, p, s, a, b, c; scanf("%d", &t); while (t--) { scanf("%d%d%d", &n, &m, &p); s = gcd(n + 2, m + 2); a = 1;b = 1;c = 1; for (int i = 3; i <= s; i++) { c = (a + b) % p; a = b; b = c; } printf("%d\n", c); } return 0; }