codeforces1025B_Weakened Common Divisor

数论的题啊…
给n对数,找出一个数是满足是n对数里至少一个数的因子,称为wcd
一般这种题就是gcd lcm 素因子什么的
所以我们用第一对数的两个数不断去和接下来的n-1对数的乘积取gcd,因为两个数的乘积就包含了这两个数的因子了,这样求出来最后再取个最大的,判断是否大于1,如果是,找出一个因子即可

代码:

#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N=2e5+50;
int n;
ll aa,bb;
ll a[N],b[N];
int main(void){
   
    scanf("%d",&n);
    scanf("%lld%lld",&aa,&bb);
    for(int i=1;i<n;i++){
   
        scanf("%lld%lld",&a[i],&b[i]);
        aa=__gcd(aa,a[i]*b[i]);
        bb=__gcd(bb,a[i]*b[i]);
    }
    ll d=max(aa,bb);
    if(d>1){
   
        //输出因子
        for(ll i=2;i*i<=d;i++){
   
            if(d%i==0){
   
                printf("%lld\n",i);
                return 0;
            }
        }
        printf("%lld\n",d);
    }else{
   
        printf("-1\n");
    }
    return 0;
}

全部评论

相关推荐

看起来名字可以很长:笑死 我暑期实习阿里云的意向也被 qq 邮箱放在垃圾箱了
点赞 评论 收藏
分享
11-23 15:14
中原工学院 Java
程序员花海_:实习和校招简历正确格式应该是教育背景+实习+项目经历+个人评价 其中项目经历注意要体现业务 实习经历里面的业务更是要自圆其说 简历模板尽可能保持干净整洁 不要太花哨的
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务