题解
2025-11-23 11:17:56
发布于:浙江
77阅读
0回复
0点赞
#include <iostream>
#include <cstdio>
#include <cmath>
using namespace std;
int gcd(int a, int b)
{
return b == 0 ? a : gcd(b, a % b);
}
int main()
{
int n;
cin >> n;
while (n-- > 0)
{
int a0, a1, b0, b1, ans = 0;
cin >> a0 >> a1 >> b0 >> b1;
int p = a0 / a1, q = b1 / b0;
for (int i = 1; i <= sqrt(b1); i++)
if (b1 % i == 0)
{
if ((i % a1 == 0) && (gcd(i / a1, p) == 1) && (gcd(q, b1 / i) == 1))
ans++;
int j = b1 / i;
if (i == j)
continue;
if ((j % a1 == 0) && (gcd(j / a1, p) == 1) && (gcd(q, b1 / j) == 1))
ans++;
}
cout << ans << endl;
}
return 0;
}
全部评论 7
d
2025-11-24 来自 浙江
8d
2025-11-23 来自 浙江
8d
2025-11-24 来自 浙江
7d
2025-11-26 来自 浙江
5d
2025-11-29 来自 浙江
4d
2025-12-05 来自 浙江
2d
2025-12-03 来自 浙江
2




















有帮助,赞一个