题意:给出 \(a_0\), \(a_1\), \(b_0\), \(b_1\), 求出正整数 \(x\) 的个数,\(x\) 满足:

\(gcd(x,a_0)=a_1\) , \(lcm(x, b_0)=b_1\) 。

题解:预备知识:设 \(a= {p_1}^{a_1}{p_2}^{{a_2}}{p_3}^{{a_3}}...{p_n}^{{a_n}}\),\(b= {p_1}^{b_1}{p_2}^{{b_2}}{p_3}^{{a_3}}...{p_n}^{{b_n}}\) ,则有:

\(gcd(a,b)={p_1}^{min(a_1,b_1)}{p_2}^{min(a_2,b_2)}{p_3}^{min(a_3,b_3)}...{p_n}^{min(a_n,b_n)}\)

\(lcm(a,b)={p_1}^{max(a_1,b_1)}{p_2}^{max(a_2,b_2)}{p_3}^{max(a_3,b_3)}...{p_n}^{max(a_n,b_n)}\)

根据题目结合上面的性质可以得到如下做法:

考虑枚举质因数 \({p_x}\) ,设 \(a_0\) 的质因数中 \(p_x\) 的系数为 \(t_1\) ,\(a_1\) 的系数为 \(t_2\) , \(x\) 的系数为 \(t\) ,由前面性质可得:\(min(t, t_1)=t_2\) 。分情况讨论:如果 \(t_1 < t_2\) ,那么无解;如果 \(t_1=t_2\) , 那么 \(t\) 要满足 \(t \geq t_2\) ;如果 \(t_1 \gt t_2\) ,那么 \(t = t_2\) .

同理,设 \(b_0\) 的质因数中 \(p_x\) 的系数为 \(t_3\) ,\(a_1\) 的系数为 \(t_4\) , \(x\) 的系数为 \(t\) ,由前面性质可得:\(max(t, t_3)=t_4\) 。分情况讨论:如果 \(t_3 \gt t_4\) ,那么无解;如果 \(t_3=t_4\) , 那么 \(t\) 要满足 \(t \leq t_4\) ;如果 \(t_3 \lt t_4\) ,那么 \(t = t_4\) .

把上面两个合并分类讨论可得:当 \(t_2=t_1\) 且 \(t_4=t_3\) 且 \(t_4 \ge t_2\) ,此时 \(t_2 \le t \le t_4\) , \(ans\) *= \(t_4-t_2+1\) .

下面是无解的 \(3\) 种情况(可简化):

  1. \(t_2=t_1\) 且 \(t_4=t_3\) 且 \(t_4 \lt t_2\),无解
  2. \(t_2 \lt t_1\) 或 \(t_4 \gt t_3\) ,无解
  3. \(t_2 \gt t_1\) 且 \(t_4 \lt t_3\) 且 $ t_2 ≠ t_4$,无解

其他情况对 \(ans\) 无影响 ( \(ans\) *= \(1\) ).

枚举质因数范围为 \(\sqrt{b_1}\) (仅枚举 \(b_1\) 的质因数),故总时间复杂度约为 $ O(n\sqrt{b_1})$ ,可以通过。

#include<cstdio>
inline int _read()
{
int x=0; char c;
for(;c<'0'||c>'9';c=getchar());
for(;c>='0'&&c<='9';c=getchar())x=(x<<1)+(x<<3)+c-'0';
return x;
}
const int N=100000;
bool b[N];
int prime[N],tot,a0,a1,b0,b1,ans;
void GetPrime()
{
for(int i=2;i<=50000;i++)
if(!b[i])
{
prime[++tot]=i;
for(long long j=1ll*i*i;j<=50000;j+=i) b[j]=true;
}
}
void work(int p)
{
int t1=0,t2=0,t3=0,t4=0;
for(;a0%p==0;a0/=p)t1++;//求次数
for(;a1%p==0;a1/=p)t2++;
for(;b0%p==0;b0/=p)t3++;
for(;b1%p==0;b1/=p)t4++;
if(t1==t2&&t3==t4)
{
if(t1<=t3) ans*=(t3-t1+1);
else ans=0; //ans=0即无解
}
if(t1<t2||t3>t4) ans=0;
if(t1>t2&&t3<t4&&t2!=t4) ans=0;
}
int main()
{
int T=_read();
GetPrime(); //预处理质数
while(T--)
{
ans=1;
a0=_read(),a1=_read(),b0=_read(),b1=_read();
for(int i=1;i<=tot;i++)
if(b1%prime[i]==0) work(prime[i]);
//枚举b1的质因数
if(b1>1) work(b1);
printf("%d\n",ans);
}
}

【NOIP2009】Hankson的趣味题的更多相关文章

  1. 洛谷P1072 [NOIP2009] Hankson 的趣味题

    P1072 Hankson 的趣味题 题目描述 Hanks 博士是 BT (Bio-Tech,生物技术) 领域的知名专家,他的儿子名叫 Hankson.现在,刚刚放学回家的 Hankson 正在思考一 ...

  2. NOIP2009 Hankson 的趣味题 : 数论

    题目描述 Hanks 博士是 BT (Bio-Tech,生物技术) 领域的知名专家,他的儿子名叫 Hankson.现在,刚刚放学回家的 Hankson 正在思考一个有趣的问题. 今天在课堂上,老师讲解 ...

  3. NOIP2009 Hankson的趣味题

    题目描述 Description Hanks 博士是BT (Bio-Tech,生物技术) 领域的知名专家,他的儿子名叫Hankson.现在,刚刚放学回家的Hankson 正在思考一个有趣的问题.今天在 ...

  4. [NOIP2009] $Hankson$ 的趣味题 (数论,gcd)

    题目链接 Solution 此题,用到的结论都是比较浅显的,但是,我竟然没想到反过来枚举... 只有50分... 被自己蠢哭... 结论比较浅显: 1.对于两个正整数\(a\),\(b\),设 \(g ...

  5. [NOIp2009] $Hankson$ 的趣味题

    类型:数论 传送门:>Here< 题意:给出四个数$a_0,a_1,b_0,b_1$,求满足$gcd(x,a_0)=a_1,lcm(x,b_0)=b_1$的$x$的个数 解题思路 显然$a ...

  6. luogu1072 [NOIp2009]Hankson的趣味题 (数学+STL::set)

    一个JSB做法 由$\frac{x*b0}{gcd(x,b0)}=b1$,可得$\frac{x}{gcd(x,b0)}=\frac{b1}{b0}$ 设$b2=\frac{b1}{b0}$ 所以对$b ...

  7. NOIP 2009 Hankson 的趣味题

    洛谷 P1072 Hankson 的趣味题 洛谷传送门 JDOJ 1648: [NOIP2009]Hankson的趣味题 T2 JDOJ传送门 Description Hanks 博士是BT (Bio ...

  8. 「NOIP2009」Hankson 的趣味题

    Hankson 的趣味题 [内存限制:$128 MiB$][时间限制:$1000 ms$] [标准输入输出][题目类型:传统][评测方式:文本比较] 题目描述 Hanks 博士是 BT(Bio-Tec ...

  9. CH3201 Hankson的趣味题

    题意 3201 Hankson的趣味题 0x30「数学知识」例题 描述 Hanks博士是BT(Bio-Tech,生物技术)领域的知名专家,他的儿子名叫Hankson.现在,刚刚放学回家的Hankson ...

  10. 算法训练 Hankson的趣味题

    算法训练 Hankson的趣味题   时间限制:1.0s   内存限制:64.0MB        问题描述 Hanks 博士是BT (Bio-Tech,生物技术) 领域的知名专家,他的儿子名叫Han ...

随机推荐

  1. 微信小程序测试request请求webapi

    using System; using System.Collections.Generic; using System.Linq; using System.Net; using System.Ne ...

  2. win10安装Oracle11g

    第一步,下载 oracle 下载地址,官网(需要登录注册): http://download.oracle.com/otn/nt/oracle11g/112010/win64_11gR2_databa ...

  3. 守神漏洞扫描器V1.2

    主界面 指纹利用 漏洞库 怎么说呢,个人感觉这个扫描器跟小哲的Test404Fuzzer差不多~ 就是功能多了旁站查询.C段查询.而且这款工具的exp比Test404Fuzzer的多了几个~ 总体来说 ...

  4. ZCGL大数据平台日常运维问题与解决方法

    问题:HBase停止 解决方法:重新启动HBase,如下所示 表层问题:插入和查询HBase速度比较慢 排查一,查看HBase节点状态,发现正常运行: 排查二,查看访问HBase服务的状态,发现服务停 ...

  5. Android 自定义PopWindow完整代码

    1.布局文件的编写 <?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:and ...

  6. Day2-J-逃离迷宫-HDU-1728

    给定一个m × n (m行, n列)的迷宫,迷宫中有两个位置,gloria想从迷宫的一个位置走到另外一个位置,当然迷宫中有些地方是空地,gloria可以穿越,有些地方是障碍,她必须绕行,从迷宫的一个位 ...

  7. 关于c++ 感想

    前言 在学校开展了c++的课程,但是不得不说相当乏味. 原因很简单: 1.感觉c++很高级,自己就这智商怎么学的会哦,自己给了自己门槛. 2.c++很难快速的做出一个能够展现的项目,缺乏成就感. 3. ...

  8. Masonry与UITableView+FDTemplateLayoutCell搭配使用

    打个小广告:本人开发了一个宠物相关的App,欢迎大家下载体验~ 下载二维码: 进入正文: 之前发过一篇博客,也是对这两个的练习使用,但是之后遇到些问题,所以删除重写了.抱歉 Masonry是一款轻量级 ...

  9. Socket传输大文件(发送与接收)

    下载 Client using System; using System.Collections.Generic; using System.Linq; using System.Text; usin ...

  10. Python面试2未完待续

    Python面试重点(基础篇) 注意:只有必答题部分计算分值,补充题不计算分值. 第一部分 必答题(每题2分) 简述列举了解的编程语言及语言间的区别? c语言是编译型语言,运行速度快,但翻译时间长py ...