NOIP2009 Hankson 的趣味题 : 数论
题目描述
Hanks 博士是 BT (Bio-Tech,生物技术) 领域的知名专家,他的儿子名叫 Hankson。现在,刚刚放学回家的 Hankson 正在思考一个有趣的问题。
今天在课堂上,老师讲解了如何求两个正整数 c1 和 c2 的最大公约数和最小公倍数。现在 Hankson 认为自己已经熟练地掌握了这些知识,他开始思考一个“求公约数”和“求公倍数”之类问题的“逆问题”,这个问题是这样的:已知正整数 a0,a1,b0,b1,设某未知正整数 x 满足:
1. x 和 a0 的最大公约数是 a1;
2. x 和 b0 的最小公倍数是 b1。
Hankson 的“逆问题”就是求出满足条件的正整数 x。但稍加思索之后,他发现这样的x 并不唯一,甚至可能不存在。因此他转而开始考虑如何求解满足条件的 x 的个数。请你帮助他编程求解这个问题。
输入输出格式
输入格式:
第一行为一个正整数 n,表示有 n 组输入数据。接下来的 n 行每行一组输入数据,为四个正整数 a0,a1,b0,b1,每两个整数之间用一个空格隔开。输入数据保证 a0 能被 a1 整除,b1 能被 b0 整除。
输出格式:
输出文件 son.out 共 n 行。每组输入数据的输出结果占一行,为一个整数。
对于每组数据:若不存在这样的 x,请输出 0;
若存在这样的 x,请输出满足条件的 x 的个数;
输入输出样例
2
41 1 96 288
95 1 37 1776
6
2
说明
【说明】
第一组输入数据,x 可以是 9、18、36、72、144、288,共有 6 个。
第二组输入数据,x 可以是 48、1776,共有 2 个。
【数据范围】
对于 50%的数据,保证有 1≤a0,a1,b0,b1≤10000 且 n≤100。
对于 100%的数据,保证有 1≤a0,a1,b0,b1≤2,000,000,000 且 n≤2000。
NOIP 2009 提高组 第二题
// 来源:洛谷
进行一波数学推导:
gcd(x, a0) = a1
—> x = k1 * a1, a0 = k 2 * a1;
—> gcd(k1, k2) = 1
  pf : 假设gcd(k1, k2) != 1;
设K = gcd(k1, k2);
    ->k1 = K * p,   k2 = K * q;
->x = p * K * a1, a0 = q * K * a1;
->gcd(x, a0) = K * a1 != a1;
假设不成立;
所以 : gcd(x, y) = k -> gcd(x / k , y / k ) = 1;
gcd(x / a1, a0 / a1) = 1;
接着
lcm(x, b0) * gcd(x, b0) = x * b0;
—> gcd(x, b0) = x * b0 / b1;
—> gcd(b1 / b0 , b1 / x) = 1;
仔细研究上面的两个等式 : x 是 a1 的倍数, x 是 b1 的约数;
可以枚举b1的约数, 然后判断上边两个等式, 成立就++;
代码:
#include <iostream>
#include <cstdio>
#include <cstring>
using namespace std;
#define ing long long int T, n;
int a0, a1, b0, b1; int Gcd(int x, int y)
{
return y == ? x : Gcd(y, x % y);
} signed main()
{
cin >> T;
while(T--)
{
int cnt = ;
scanf("%lld%lld%lld%lld", &a0, &a1, &b0, &b1); for(register int i = ; i * i <= b1 ; i ++)
{
if(b1 % i != ) continue; int g = Gcd(i / a1 , a0 / a1);
int gg = Gcd(b1 / b0, b1 / i); if(i % a1 == && g == && gg == )
{
cnt++;
} int j = b1 / i; if(i == j) continue; int c = Gcd(j / a1, a0 / a1);
int cc = Gcd(b1 / b0, b1 / j); if(j % a1 == && c == && cc == ) cnt++; } printf("%lld\n", cnt);
}
return ; }
zZhBr
NOIP2009 Hankson 的趣味题 : 数论的更多相关文章
- [NOIP2009] $Hankson$ 的趣味题 (数论,gcd)
		题目链接 Solution 此题,用到的结论都是比较浅显的,但是,我竟然没想到反过来枚举... 只有50分... 被自己蠢哭... 结论比较浅显: 1.对于两个正整数\(a\),\(b\),设 \(g ... 
- 1172 Hankson 的趣味题[数论]
		1172 Hankson 的趣味题 2009年NOIP全国联赛提高组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题解 题目描述 Descrip ... 
- 洛谷P1072 [NOIP2009] Hankson 的趣味题
		P1072 Hankson 的趣味题 题目描述 Hanks 博士是 BT (Bio-Tech,生物技术) 领域的知名专家,他的儿子名叫 Hankson.现在,刚刚放学回家的 Hankson 正在思考一 ... 
- NOIP2009 Hankson的趣味题
		题目描述 Description Hanks 博士是BT (Bio-Tech,生物技术) 领域的知名专家,他的儿子名叫Hankson.现在,刚刚放学回家的Hankson 正在思考一个有趣的问题.今天在 ... 
- [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 ... 
- P1072 Hankson 的趣味题[数论]
		题目描述 Hanks 博士是 BT(Bio-Tech,生物技术) 领域的知名专家,他的儿子名叫 Hankson.现在,刚刚放学回家的 Hankson 正在思考一个有趣的问题. 今天在课堂上,老师讲解了 ... 
- 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 ... 
随机推荐
- ACM团队招新赛题解
			标程代码全部为C语言编写.代码中的#if LOCAL_ 至#endif为本地一些调试内容,可以忽略. Xenny的A+B(1)[容易][签到] 签到题,做不出的话可能你有点不太适合ACM了. Xenn ... 
- Linux环境下进行分布式压测踩过的坑
			背景:公司为了满足大并发的情况,需要测试组配合,就需要分布式压测,这里我把我踩过坑都记录下来: 环境:Linux + jmeter-v.5.1.1;使用3台2核4G的压力机: Q1: Server f ... 
- 连环清洁工之特殊任务--java资源如何关闭?
			小C是一名特殊的黑客,他专门为黑客提供服务,扫除黑客攻击的痕迹,避免被查到为何人攻击. 今天他正兴致勃勃的玩游戏<连环清洁工>,连环清洁工是由iFun4all S.A.制作发行的一款犯罪题 ... 
- 用 C# 来守护 Python 进程
			背景 目前我主要负责的一个项目是一个 C/S 架构的客户端开发,前端主要是通过 WPF 相关技术来实现,后端是通过 Python 来实现,前后端的数据通信则是通过 MQ 的方式来进行处理.由于 Pyt ... 
- 基于MFCC的语音数据特征提取概述
			1. 概述 语音是人类之间沟通交流的最直接也是最快捷方便的一种手段,而实现人类与计算机之间畅通无阻的语音交流,一直是人类追求的一个梦想. 伴随着移动智能设备的普及,各家移动设备的厂家也开始在自家的设备 ... 
- Android Studio [真机测试/开发者模式]
			一.手机设置 首先根据自己的手机型号百度打开开发者模式, 我的是vivo,设置--->更多设置-->关于手机-->软件版本号连续点击会提示开启开发者模式. 并在开发者选项里打开USB ... 
- Android Studio [跑马灯]
			MainActivity package com.xdw.secondapp; import android.graphics.Paint; import android.support.v7.app ... 
- Spring Boot 2.x基础教程:构建RESTful API与单元测试
			首先,回顾并详细说明一下在快速入门中使用的@Controller.@RestController.@RequestMapping注解.如果您对Spring MVC不熟悉并且还没有尝试过快速入门案例,建 ... 
- Tomcat+Nginx+Linux+Mysql部署豆瓣TOP250的项目到腾讯云服务器
			写在前面 因为前面有写过一篇关于豆瓣的top250的电影的可视化展示项目,你可以移步http://blog.csdn.net/liuge36/article/details/78607955了解这个项 ... 
- MySQL 分页查询优化
			有时在处理偏移量非常大的分页时候查询时,例如LIMIT 1000,10这样的查询,这时MySQL需要查询1010条记录然后只返回最后10条,前面1000条记录都被抛弃,这样的代价非常高.要优化这种查询 ... 
