[题解](gcd/lcm)luogu_P1072_Hankson的趣味题(NOIP2009)
连续三次不开longlong导致wa!!!
不开longlong一时爽,一会提交火葬场!!!
OI千万条,longlong第一条
乘法不longlong,提交两行泪
暴力luogu就能过了???打好暴力的重要性!!!(事实上只能拿90分)
1.暴力
根据lcm(x,b0)==b1可以发现x一定是b1的约数,所以枚举用试除法b1的约数,暴力判断是否符合条件
(数学题发现性质的重要性
复杂度O(n*sqrt(b1)*log(b1)),预处理出1~sqrt(2*1e9)的所有质数,用搜索组成d的所有约数,在判断是否满足可过
#include<bits/stdc++.h>
#define ll long long
using namespace std;
ll aa,ba,ab,bb,ans;
inline ll gcd(ll a,ll b){
return b?gcd(b,a%b):a;
}
inline ll lcm(ll a,ll b){
return a*b/gcd(a,b);
}
void div(ll n){
for(int i=;i*i<=n;i++){
if(n%i==){
ll g=gcd(i,aa),l=lcm(i,ba);
if(g==ab && l==bb)ans++;
if(n/i!=i){
ll g=gcd(n/i,aa),l=lcm(n/i,ba);
if(g==ab && l==bb)ans++;
}
}
}
}
int main(){int T;
scanf("%d",&T);
while(T--){
ans=;
scanf("%d%d%d%d",&aa,&ab,&ba,&bb);
div(bb);
printf("%lld\n",ans);
}
}
2.正解
因为x是b1的约数,所以x的质因子一定是b1的质因子。可以对b1的每个质因子p,计算x可能包含多少个p。
设a0,a1,b0,b1,x有质因子p个数为ma0,ma1,mb0,mb1,mx,mx未知
思考可以得出:
对于gcd(x,a0)=a1:
(1)若ma0>ma1,则mx只能等于ma1
(2)若ma0==ma1,则只需满足mx>=ma1
(3)若ma0<ma1,无解
对于lcm(x,b0)=b1:
(1)若mb0<mb1,mx只能等于mb1
(2)若mb0==mb1,只需满足mx<=mb1
(3)若mb0>mb1,无解
综合分类讨论(恶心),其他情况组合判断即可
对于ma0==ma1 && mb0==mb1的情况,只要保持在ma1<=mx<=mb1的范围内取值即可,共有md-mc+1种取法
每个质因子都是相对独立的,根据乘法原理,总取值即为每次的答案相乘。
预处理出1~sqrt(1e9)中的素数,若b1为质数,那么直接计算有质因子b1的个数即可
复杂度O(n*sqrt(b1)/ log(b1))
#include<bits/stdc++.h>
#define ll long long
using namespace std;
//±©Á¦£º
//ll aa,ba,ab,bb,ans;
//inline ll gcd(ll a,ll b){
// return b?gcd(b,a%b):a;
//}
//inline ll lcm(ll a,ll b){
// return a*b/gcd(a,b);
//}
//void div(ll n){
// for(int i=1;i*i<=n;i++){
// if(n%i==0){
// ll g=gcd(i,aa),l=lcm(i,ba);
// if(g==ab && l==bb)ans++;
// if(n/i!=i){
// ll g=gcd(n/i,aa),l=lcm(n/i,ba);
// if(g==ab && l==bb)ans++;
// }
// }
// }
//}
//int main(){int T;
// scanf("%d",&T);
// while(T--){
// ans=0;
// scanf("%d%d%d%d",&aa,&ab,&ba,&bb);
// div(bb);
// printf("%lld\n",ans);
// }
//}
//Õý½â£º
ll aa,ba,ab,bb,ans=;
int prime[],ck[],tot;
inline void div(int p){
int ma0=,ma1=,mb0=,mb1=;
while(aa%p==){ma0++;aa/=p;}
while(ab%p==){ma1++;ab/=p;}
while(ba%p==){mb0++;ba/=p;}
while(bb%p==){mb1++;bb/=p;}
if((ma0<ma1)||(mb0>mb1)) ans=;
else if((ma0==ma1)&&(mb0<mb1) || (ma0>ma1)&&(mb0==mb1)){
if(ma1>mb1)ans=;
}
else if((ma0==ma1)&&(mb0==mb1)){
if(ma1<=mb1)ans*=(mb1-ma1+);
else ans=;
}
else if((ma0>ma1)&&(mb0<mb1)){
if(ma1!=mb1)ans=;
}
}
int main(){
for(int i=;i<=;i++){
if(!ck[i])prime[++tot]=i;
for(int j=;j<tot;j++){
if(i*prime[j]>)break;
ck[i*prime[j]]=;
if(i%prime[j]==)break;
}
}
int T;
scanf("%d",&T);
while(T--){
ans=;
scanf("%d%d%d%d",&aa,&ab,&ba,&bb);
for(int i=;i<=tot;i++){
div(prime[i]);
if(ans==)break;
}
if(bb>)div(bb);//²»È»»áwaÒ»¸öµã
printf("%lld\n",ans);
}
}
[题解](gcd/lcm)luogu_P1072_Hankson的趣味题(NOIP2009)的更多相关文章
- CodeForces 992B Nastya Studies Informatics + Hankson的趣味题(gcd、lcm)
http://codeforces.com/problemset/problem/992/B 题意: 给你区间[l,r]和x,y 问你区间中有多少个数对 (a,b) 使得 gcd(a,b)=x lc ...
- 「NOIP2009」Hankson 的趣味题
Hankson 的趣味题 [内存限制:$128 MiB$][时间限制:$1000 ms$] [标准输入输出][题目类型:传统][评测方式:文本比较] 题目描述 Hanks 博士是 BT(Bio-Tec ...
- 洛谷P1072 [NOIP2009] Hankson 的趣味题
P1072 Hankson 的趣味题 题目描述 Hanks 博士是 BT (Bio-Tech,生物技术) 领域的知名专家,他的儿子名叫 Hankson.现在,刚刚放学回家的 Hankson 正在思考一 ...
- [ 9.13 ]CF每日一题系列—— 340A GCD & LCM
Description: [ 着实比较羞愧,都想着去暴力,把算法(方法)也忘了] A只涂x,2x,3x……,B只涂y,2y,3y……问你A和B共同涂的墙的个数 Solution: 就是求x和y的lcm ...
- NOIP 2009 Hankson 的趣味题
洛谷 P1072 Hankson 的趣味题 洛谷传送门 JDOJ 1648: [NOIP2009]Hankson的趣味题 T2 JDOJ传送门 Description Hanks 博士是BT (Bio ...
- 1172 Hankson 的趣味题[数论]
1172 Hankson 的趣味题 2009年NOIP全国联赛提高组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题解 题目描述 Descrip ...
- luogu P1072 Hankson的趣味题
题目链接 luogu P1072 Hankson 的趣味题 题解 啊,还是noip的题好做 额,直接推式子就好了 \(gcd(x,a_0)=a_1=gcd(\frac{x}{a_1},\frac{a_ ...
- 算法训练 Hankson的趣味题
算法训练 Hankson的趣味题 时间限制:1.0s 内存限制:64.0MB 问题描述 Hanks 博士是BT (Bio-Tech,生物技术) 领域的知名专家,他的儿子名叫Han ...
- 1172 Hankson 的趣味题
1172 Hankson 的趣味题 2009年NOIP全国联赛提高组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题解 题目描述 Descrip ...
随机推荐
- linux LVM:物理卷逻辑卷
逻辑卷管理器,当分区不够用的时候,可以新建一个更大的分区再复制进去,但是浪费时间.Lvm可以弹性调整分区大小,可以动态组合分区.分区大小固定了就无法调整, apt-get update & a ...
- [coci2012]覆盖字符串 AC自动机
给出一个长度为N的小写字母串,现在Mirko有M个若干长度为Li字符串.现在Mirko要用这M个字符串去覆盖给出的那个字符串的.覆盖时,必须保证:1.Mirko的字符串不能拆开,旋转:2.Mirko的 ...
- Android源码的编译和下载【转】
本文转载自:http://blog.csdn.net/banketree/article/details/9089827 网上介绍下载.编译Android方法一坨,读万卷书不如行万里路,以下是笔者亲身 ...
- 人生苦短之Python文件的IO操作
在Python中也有涉及到文件的相关操作,从最简单的文件读取说起 文件读取 file = open('/Users/macbookpro/Desktop/使用教程.txt', 'r', encodin ...
- Redis雪崩效应以及解决方案
缓存雪崩产生的原因 缓存雪崩通俗简单的理解就是:由于原有缓存失效(或者数据未加载到缓存中),新缓存未到期间(缓存正常从Redis中获取,如下图)所有原本应该访问缓存的请求都去查询数据库了,而对数据库C ...
- html5--5-12 渐变色
html5--5-12 渐变色 学习要点 掌握渐变色的绘制方法 渐变色绘制方法 createLinearGradient() 创建线性渐变 createLinearGradient(x1,y1,x2, ...
- css中块元素和行内元素区别
行内元素特点 1.和其他元素都在一行上: 2.元素的高度.宽度.行高及顶部和底部边距不可设置: 3.元素的宽度就是它包含的文字或图片的宽度,不可改变. 块元素特点 1.每个块级元素都从新的一行开始,并 ...
- Java网络编程Socket通信
TCP(Transmission Control Protocol 传输控制协议)是一种面向连接的.可靠的.基于字节流的传输层通信协议 UDP (User Datagram Proto ...
- CISCO-配置SSH
PC直接连在交换机端口上,PC的ip地址是:192.168.1.1/24 在交换机的操作步骤如下: 1.设置交换机管理ip Switch#conf t Switch(config)#int vlan ...
- chan_ss7 呼出的时候指定使用某个CICs,或者CICs范围 的方法
Linkset one: 1-31 Incoming 33-58 Outgoing 58-63 Emergency Traffic Linkset two: 1-31 Incoming 33-58 ...