博客
关于我
HDU - 4497 GCD and LCM 数论gcd
阅读量:269 次
发布时间:2019-03-01

本文共 2318 字,大约阅读时间需要 7 分钟。

文章目录

题意:

给三个数的 l c m lcm lcm g c d gcd gcd,求满足条件的三元组组合个数。

思路:

首先 l c m   m o d   g c d = = 0 lcm\bmod gcd==0 lcmmodgcd==0是有组合的条件,否则输出0。

现在可知 l c m ( x ′ , y ′ , z ′ ) = l c m ( x , y , z ) g c d ( x , y , z ) , g c d ( x ′ , y ′ , z ′ ) = 1 lcm(x^{'},y^{'},z^{'})=\frac{lcm(x,y,z)}{gcd(x,y,z)},gcd(x^{'},y^{'},z^{'})=1 lcm(x,y,z)=gcd(x,y,z)lcm(x,y,z)gcd(x,y,z)=1,对 a a a分解质因子得到 p 1 u 1 p 2 u 2 . . . p n u n p_1^{u_1}p_2^{u_2}...p_n^{u_n} p1u1p2u2...pnun,假设 x ′ = p 1 i 1 p 2 i 2 . . . p n j n , y ′ = p 1 j 1 p 2 j 2 . . . p n j n , z ′ = p 1 k 1 p 2 k 2 . . . p n k n x^{'}=p_1^{i_1}p_2^{i_2}...p_n^{j_n},y^{'}=p_1^{j_1}p_2^{j_2}...p_n^{j_n},z^{'}=p_1^{k_1}p_2^{k_2}...p_n^{k_n} x=p1i1p2i2...pnjn,y=p1j1p2j2...pnjn,z=p1k1p2k2...pnkn。那么由于 g c d ( x ′ , y ′ , z ′ ) = 1 gcd(x^{'},y^{'},z^{'})=1 gcd(x,y,z)=1,可知 m i n ( i 1 , j 1 , k 1 ) = 0 min(i_1,j_1,k_1)=0 min(i1,j1,k1)=0, m a x ( i 1 , j 1 , k 1 ) = u 1 max(i_1,j_1,k_1)=u_1 max(i1,j1,k1)=u1,所以我们需要找出来一个位置取 0 0 0,一个位置取 u 1 u_1 u1,其他的位置随意就好了。当前位置的答案即为 A 3 2 ∗ u 1 = 6 ∗ u 1 A_3^2*u_1=6*u_1 A32u1=6u1,那么 a n s = ∑ 6 ∗ u i ans=\sum6*u_i ans=6ui

//#pragma GCC optimize(2)#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#define X first#define Y second#define L (u<<1)#define R (u<<1|1)#define pb push_back#define mk make_pair#define Mid (tr[u].l+tr[u].r>>1)#define Len(u) (tr[u].r-tr[u].l+1)#define random(a,b) ((a)+rand()%((b)-(a)+1))#define db puts("---")using namespace std;//void rd_cre() { freopen("d://dp//data.txt","w",stdout); srand(time(NULL)); }//void rd_ac() { freopen("d://dp//data.txt","r",stdin); freopen("d://dp//AC.txt","w",stdout); }//void rd_wa() { freopen("d://dp//data.txt","r",stdin); freopen("d://dp//WA.txt","w",stdout); }typedef long long LL;typedef unsigned long long ULL;typedef pair
PII;const int N=1000010,mod=1e9+7,INF=0x3f3f3f3f;const double eps=1e-6;LL g,l;int main(){ // ios::sync_with_stdio(false);// cin.tie(0); int _; scanf("%d",&_); while(_--) { scanf("%lld%lld",&g,&l); if(l%g!=0) { puts("0"); continue; } LL x=l/g; map
mp; for(int i=2;i<=x/i;i++) if(x%i==0) while(x%i==0) x/=i,mp[i]++; if(x>1) mp[x]++; LL ans=1; for(auto x:mp) ans*=6*x.Y; printf("%lld\n",ans); } return 0;}/**/

转载地址:http://hplx.baihongyu.com/

你可能感兴趣的文章
Nginx配置负载均衡到后台网关集群
查看>>
ngrok | 内网穿透,支持 HTTPS、国内访问、静态域名
查看>>
NHibernate学习[1]
查看>>
NHibernate异常:No persister for的解决办法
查看>>
NIFI1.21.0_Mysql到Mysql增量CDC同步中_日期类型_以及null数据同步处理补充---大数据之Nifi工作笔记0057
查看>>
NIFI1.21.0_NIFI和hadoop蹦了_200G集群磁盘又满了_Jps看不到进程了_Unable to write in /tmp. Aborting----大数据之Nifi工作笔记0052
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
查看>>
NIFI1.23.2_最新版_性能优化通用_技巧积累_使用NIFI表达式过滤表_随时更新---大数据之Nifi工作笔记0063
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现数据实时delete同步_实际操作04---大数据之Nifi工作笔记0043
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_03_来吧用NIFI实现_数据分页获取功能---大数据之Nifi工作笔记0038
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_无分页功能_02_转换数据_分割数据_提取JSON数据_替换拼接SQL_添加分页---大数据之Nifi工作笔记0037
查看>>
NIFI从PostGresql中离线读取数据再导入到MySql中_带有数据分页获取功能_不带分页不能用_NIFI资料太少了---大数据之Nifi工作笔记0039
查看>>
nifi使用过程-常见问题-以及入门总结---大数据之Nifi工作笔记0012
查看>>
NIFI分页获取Mysql数据_导入到Hbase中_并可通过phoenix客户端查询_含金量很高的一篇_搞了好久_实际操作05---大数据之Nifi工作笔记0045
查看>>
NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
查看>>
Nifi同步过程中报错create_time字段找不到_实际目标表和源表中没有这个字段---大数据之Nifi工作笔记0066
查看>>
NIFI大数据进阶_FlowFile拓扑_对FlowFile内容和属性的修改删除添加_介绍和描述_以及实际操作---大数据之Nifi工作笔记0023
查看>>
NIFI大数据进阶_NIFI的模板和组的使用-介绍和实际操作_创建组_嵌套组_模板创建下载_导入---大数据之Nifi工作笔记0022
查看>>