【NOIP2009】Hankson的趣味题
题意:给出 \(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\) 种情况(可简化):
- \(t_2=t_1\) 且 \(t_4=t_3\) 且 \(t_4 \lt t_2\),无解
- \(t_2 \lt t_1\) 或 \(t_4 \gt t_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的趣味题的更多相关文章
- 洛谷P1072 [NOIP2009] Hankson 的趣味题
P1072 Hankson 的趣味题 题目描述 Hanks 博士是 BT (Bio-Tech,生物技术) 领域的知名专家,他的儿子名叫 Hankson.现在,刚刚放学回家的 Hankson 正在思考一 ...
- NOIP2009 Hankson 的趣味题 : 数论
题目描述 Hanks 博士是 BT (Bio-Tech,生物技术) 领域的知名专家,他的儿子名叫 Hankson.现在,刚刚放学回家的 Hankson 正在思考一个有趣的问题. 今天在课堂上,老师讲解 ...
- NOIP2009 Hankson的趣味题
题目描述 Description Hanks 博士是BT (Bio-Tech,生物技术) 领域的知名专家,他的儿子名叫Hankson.现在,刚刚放学回家的Hankson 正在思考一个有趣的问题.今天在 ...
- [NOIP2009] $Hankson$ 的趣味题 (数论,gcd)
题目链接 Solution 此题,用到的结论都是比较浅显的,但是,我竟然没想到反过来枚举... 只有50分... 被自己蠢哭... 结论比较浅显: 1.对于两个正整数\(a\),\(b\),设 \(g ...
- [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 ...
- 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 ...
- NOIP 2009 Hankson 的趣味题
洛谷 P1072 Hankson 的趣味题 洛谷传送门 JDOJ 1648: [NOIP2009]Hankson的趣味题 T2 JDOJ传送门 Description Hanks 博士是BT (Bio ...
- 「NOIP2009」Hankson 的趣味题
Hankson 的趣味题 [内存限制:$128 MiB$][时间限制:$1000 ms$] [标准输入输出][题目类型:传统][评测方式:文本比较] 题目描述 Hanks 博士是 BT(Bio-Tec ...
- CH3201 Hankson的趣味题
题意 3201 Hankson的趣味题 0x30「数学知识」例题 描述 Hanks博士是BT(Bio-Tech,生物技术)领域的知名专家,他的儿子名叫Hankson.现在,刚刚放学回家的Hankson ...
- 算法训练 Hankson的趣味题
算法训练 Hankson的趣味题 时间限制:1.0s 内存限制:64.0MB 问题描述 Hanks 博士是BT (Bio-Tech,生物技术) 领域的知名专家,他的儿子名叫Han ...
随机推荐
- The Google File System中文版
译者:alex 摘要 我们设计并实现了Google GFS文件系统,一个面向大规模数据密集型应用的.可伸缩的分布式文件系统.GFS虽然运行在廉价的普遍硬件设备上,但是它依然了提供灾难冗余的能力,为大量 ...
- Oracle10g下载地址
Oracle Database 10g Release 2 (10.2.0.1.0) Enterprise/Standard Edition for Microsoft Windows (32-bit ...
- 十一 队列 Queue
队列: 一种先进先出的数据结构 FIFO 数组队列的实现:
- drugs
1. 摘录:未来简史 2. 毒品禁药扫盲 3. 毒品争议 4. 部分毒品列表 5. 影视作品里常出现的几种毒品 1. 摘录:未来简史 第一章 人类的新议题 幸福快乐的权利 (P36) 人们喝酒是为了遗 ...
- 牛客NOIPtg day5 B-demo的gcd
一句话题意:给定长度为n的序列,求任意两两之间gcd的积mod 998244353的值. 好像是莫比乌斯反演板子题???(反正noip估计不考这种毒瘤 考场上想到一个类似正解的思路 好像摊下来最多处理 ...
- 「SCOI2005」栅栏
传送门 Luogu 解题思路 我们有很显然的这样一条贪心思路: 首先满足长度短的木板,因为如果可以满足长的也肯定可以满足短的,而且可能满足更多. 那么我们就会有这样的思路:枚举一条木板由哪条木板切割而 ...
- 5.8 Nginx 常用功能的配置
- 每个项目中,你必须知道的11个Java第三方类库。
Java第三方library ecosystem是一个很广阔的范畴.不久前有人撰文:每个项目中,你必须知道的11个Java第三方类库. 单元测试 1.DBUnit DBunit是一个基于junit扩展 ...
- MyBatis学习之简单增删改查操作、MyBatis存储过程、MyBatis分页、MyBatis一对一、MyBatis一对多
一.用到的实体类如下: Student.java package com.company.entity; import java.io.Serializable; import java.util.D ...
- MVC、MVT简介
一.MVC MVC的产生理念: 分工.让专门的人去做专门的事. MVC的核心思想: 解耦. M: Model,模型, 和数据库进行交互. V: View,视图, 产生html页面. C: Contro ...