博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
POJ 2773 Happy 2006
阅读量:6982 次
发布时间:2019-06-27

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

数论的一道题目 

k很大,感觉暴搜会超时,但是最后还是没有想出来 看别人的解释后 发现好神啊 

先来看看求两个数的最大公约数的求法    对于 x y (假设x>y)

若 x%y==0  则说明最大公约数为y

若!=0   则 要继续 递归求解    gcd(y,x%y)

从求最大公约数过程可以看出   gcd(x,y)=1,则 gcd(x*n+y,x)=1(第一步为 (x*n+y)%x=y    第二步 为 gcd(x,y),所以两个的最大公约数也应为1  )

故 只需求出 m内的最大公约数为1 的数 ,超过部分可通过这些数得出 。。。

#include
#define N 1000005int pto[N];int gcd(int x,int y){ if(x%y==0)return y; return gcd(y,x%y);}int main(){ int i,t,ans,m,k; while(scanf("%d%d",&m,&k)!=EOF) { t=0; for(i=1;i<=m;i++) //注意i=m时要判断 因为m=1时 就要加入pto数组中 if(gcd(m,i)==1)pto[t++]=i; ans=k/t; k%=t; if(k!=0)printf("%I64d\n",__int64(ans*m+pto[k-1])); else printf("%I64d\n",__int64((ans-1)*m+pto[t-1])); } return 0;}

 

 

 

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

你可能感兴趣的文章
从头写个http client(java)
查看>>
Windows Phone笔记索引(总)
查看>>
1分钟破解3dState '学习版'得一些版权信息。
查看>>
我和linux
查看>>
动态调用webservice
查看>>
Java刷题知识点之方法覆盖(方法重写)和方法重载的区别
查看>>
爆牙齿的世界杯日记(小组首轮)
查看>>
ITTC数据挖掘平台介绍(四) 框架改进和新功能
查看>>
JDK5.0新特性系列---11.4线程 Condition
查看>>
Software development --daily scrum team
查看>>
【原】macbook不睡眠的排查与解决
查看>>
用HttpListener做web服务器,简单解析post方式过来的参数、上传的文件
查看>>
ubuntu 12.04解决Broadcom STA无线网卡驱动安装失败解决
查看>>
【CSWS2014 Summer School】互联网广告中的匹配和排序算法-蒋龙(上)
查看>>
连续启动 crash 自修复技术实现与原理解析
查看>>
C#基础回顾:GridView全选演示
查看>>
Wintel物联网平台-Windows IoT新手入门指南
查看>>
解决linux下无线网卡被物理禁用问题
查看>>
批处理脚本, 读取文件并字符串替换
查看>>
SQL Server误区30日谈-Day27-使用BACKUP ... WITH CHECKSUM可以替代DBCC CheckDB
查看>>