其他的几篇题解大多都是先求了 \(c_i \gets lcm(a_i,b_i)\) ,然后求全部 \(c_i\) 的最大公约数,但是对每一组数都求一下 \(lcm(a_i,b_i)\) 会增加时间复杂度,所以直接把 \(a_i\) ,\(b_i\) 乘起来就行,不妨记录 \(a_i*b_i\) 为 \(c_i\) 最后再求所以 \(c_i\) 的最大公约数,求所以 \(c_i\) 的最大公约数的方法是先求 \(now \gets gcd(c_{i-1},c_{i-2})\) ,然后再求 \(gcd(now,c_i)\) ,为什么 \(gcd(a,b,c)=gcd(gcd(a,b),c)\) 呢,因为

\[
gcd(a,b)=\prod_{p} p^{min(a_p,b_p)}
\]

其中 \(a_p\) 与 \(b_p\) 为 \(a,b\) 质因数 \(p\) 的指数,记上面这个大式子为 \(q\) ,那么

\[
gcd(q,b)=\prod_{p} p^{min(q_p,c_p)}=\prod_{p} p^{min(min(a_p,b_p),c_p)}
\]

因为 \(min(min(a,b),c)\) 等价于 \(min(a,b,c)\) ,即 \(min\) 满足结合律 ,所以 \(gcd\) 也是满足结合律的。

当然求出所以 \(c_i\) 的最大公约数(记作 \(ans\) )是不满足要求的 ,但是因为 \(ans\) 的质因数一定在所以 \(c_i\) 中都有,所以 \(ans\) 的质因数一定是在与 \(c_i\) 对应的 \(a_i\) ,\(b_i\) 至少一个中存在 ,且指数小于等于 \(min(a_p,b_p)\) ,所以输出 \(ans\) 输出一个质因数即可,显然当所有 \(c_i\) 的最大公约数为 \(1\) 时不存在 ,但是这题有点卡质因数分解 ,所以判断一下选 \(a_1\) 还是 \(b_1\) 然后与 \(ans\) 取个最大公约数能减小要分解的数的大小 ,具体见代码实现

代码实现:

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
ll read()
{
ll X=0,w=0;char ch=0;
while(!isdigit(ch)){w|=ch=='-';ch=getchar();}
while(isdigit(ch)){X=(X<<3)+(X<<1)+(ch^48);ch=getchar();}
return w?-X:X;
} void write(ll x)
{
if(x<0){putchar('-');x=-x;}
if(x>9){write(x/10);}
putchar(x%10+'0');
}
ll gcd(ll a,ll b){return b?gcd(b,a%b):a;}
ll lcm(ll a,ll b){return a*b/gcd(a,b);}
struct node
{
ll a,b,l; };
ll f(ll x)
{
for(int i=2;i<=sqrt(x);i++)
{
if(x%i==0){
return i;
}
}
return x;
}
int main()
{
ll n=read();
node arr[150000];
ll aaa,bbb;
cin>>aaa>>bbb;
for(int i=1;i<n;i++)
{
arr[i].a=read();
arr[i].b=read();
arr[i].l=arr[i].a*arr[i].b;
aaa=gcd(arr[i].a*arr[i].b,aaa);
bbb=gcd(arr[i].a*arr[i].b,bbb);
}
ll now=gcd(arr[0].l,arr[1].l);
for (int i=2;i<n;i++)
{
now=gcd(now,arr[i].l);
}
if(now==1)
{
cout<<"-1";
return 0;
}
if(aaa!=1)
{
cout<<f(aaa);
}
else if(bbb!=1) cout<<f(bbb);
else cout<<"-1";
return 0;
}

CF1025B题解的更多相关文章

  1. CF1025B Weakened Common Divisor 题解

    Content 定义 \(n\) 个数对 \((a_1,b_1),(a_2,b_2),(a_3,b_3),...,(a_n,b_n)\) 的 \(\text{WCD}\) 为能够整除每个数对中至少一个 ...

  2. 2016 华南师大ACM校赛 SCNUCPC 非官方题解

    我要举报本次校赛出题人的消极出题!!! 官方题解请戳:http://3.scnuacm2015.sinaapp.com/?p=89(其实就是一堆代码没有题解) A. 树链剖分数据结构板题 题目大意:我 ...

  3. noip2016十连测题解

    以下代码为了阅读方便,省去以下头文件: #include <iostream> #include <stdio.h> #include <math.h> #incl ...

  4. BZOJ-2561-最小生成树 题解(最小割)

    2561: 最小生成树(题解) Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1628  Solved: 786 传送门:http://www.lyd ...

  5. Codeforces Round #353 (Div. 2) ABCDE 题解 python

    Problems     # Name     A Infinite Sequence standard input/output 1 s, 256 MB    x3509 B Restoring P ...

  6. 哈尔滨理工大学ACM全国邀请赛(网络同步赛)题解

    题目链接 提交连接:http://acm-software.hrbust.edu.cn/problemset.php?page=5 1470-1482 只做出来四道比较水的题目,还需要加强中等题的训练 ...

  7. 2016ACM青岛区域赛题解

    A.Relic Discovery_hdu5982 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Jav ...

  8. poj1399 hoj1037 Direct Visibility 题解 (宽搜)

    http://poj.org/problem?id=1399 http://acm.hit.edu.cn/hoj/problem/view?id=1037 题意: 在一个最多200*200的minec ...

  9. 网络流n题 题解

    学会了网络流,就经常闲的没事儿刷网络流--于是乎来一发题解. 1. COGS2093 花园的守护之神 题意:给定一个带权无向图,问至少删除多少条边才能使得s-t最短路的长度变长. 用Dijkstra或 ...

随机推荐

  1. 视频动作定位的分层自关注网络:ICCV2019论文解析

    视频动作定位的分层自关注网络:ICCV2019论文解析 Hierarchical Self-Attention Network for Action Localization in Videos 论文 ...

  2. 开发掉坑(一)tar命令解压文件覆盖源文件

    今天在编译机上编译前端代码,报了找不到依赖的异常.检查后发现是node_modules/.bin下少了一些文件. 一开始疑惑为什么本地能成功生成软链在node_modules/.bin,服务器上面却不 ...

  3. MySQL笔记03(黑马)

    今日内容 DQL:查询语句 排序查询 聚合函数 分组查询 分页查询 约束 多表之间的关系 范式 数据库的备份和还原 DQL:查询语句 排序查询 语法:order by 子句 order by 排序字段 ...

  4. 《手把手教你》系列基础篇之(一)-java+ selenium自动化测试-环境搭建(上)(详细教程)

    1.简介 jmeter系列的文章结束,本来想趁热打铁顺别将Jmeter和接口测试介绍一下,但是感觉Jmeter时间太长了怕大家吃腻了,还有一个原因就是许多小伙伴们或者童鞋们私信问宏哥什么时候可以有ja ...

  5. 【模拟8.03】斐波那契(fibonacci) (规律题)

    就是找规律,发现每个父亲和孩子的差值都是距儿子最大的fibonacc 也是可证的 f[i]表示当前月的兔子总数 f[i]=f[i-1]+f[i-2](f[i-2]是新生的,f[i-1]是旧有的) 然后 ...

  6. org.junit.Assert(断言)

    org.junit.Assert(断言) Assert是断言的意思,可以理解为"猜测",如果猜测错误,则抛出java.lang.AssertionError异常.  引入jar包  ...

  7. 解决mac中adb: command not found

    在Mac系统中,很多时候第一次在Android SDK中使用adb的时候.无法使用.会提示-bash: abd: command not found. 造成此类现象的原因是:未配置Android的环境 ...

  8. split截取字符串

    一.根据单个分隔字符用split截取字符串:string st="GT123_1";split代码:string[] sArray=st.split("_"); ...

  9. LVM与磁盘配额

    LVM与磁盘配额 目录 一.LVM概述 1.1.LVM 概述 1.2.LVM机制的基本概念 二.LVM 管理命令 2.1.主要命令 2.2.LVM命令详解 三.设置磁盘配额 3.1.磁盘配额的概述 3 ...

  10. 中文NER的那些事儿3. SoftLexicon等词汇增强详解&代码实现

    前两章我们分别介绍了NER的基线模型Bert-Bilstm-crf, 以及多任务和对抗学习在解决词边界和跨领域迁移的解决方案.这一章我们就词汇增强这个中文NER的核心问题之一来看看都有哪些解决方案.以 ...