比赛 板子大赛 评测结果 AAAAAAAAAA
题目名称 最大公约数和最小公倍数问题 最终得分 100
用户昵称 zqy 运行时间 0.029 s
代码语言 C++ 内存使用 3.31 MiB
提交时间 2025-01-22 10:32:50
显示代码纯文本
#include <iostream>
#include <cstdio>
using namespace std;
int gcd(int m,int n){
    return n==0?m:gcd(n,m%n);
}
int lcm(int m,int n){
    return m/gcd(m,n)*n;
}
int a,b,x[10005],cnt,ans;
int main(){
    freopen("gcdpro.in","r",stdin);
    freopen("gcdpro.out","w",stdout);
    cin>>a>>b;
    for(int i=1;i*i<=b;i++){
        if(b%i==0){
            x[++cnt]=i;
            if(i*i!=b)x[++cnt]=b/i;
        }
    }
    for(int i=1;i<=cnt;i++){
        for(int j=1;j<=cnt;j++){
            if(lcm(x[i],x[j])==b&&gcd(x[i],x[j])==a)ans++;
        }
    }
    cout<<ans<<endl;
    return 0;
}