#include<stdio.h>
#include<stdlib.h>
#include<time.h>
#include<math.h>
#include<algorithm>
#define MAXN 100000
using namespace std;
typedef unsigned long long LL;
LL fac[MAXN],cnt,G,L,m,p;
LL min(LL a,LL b)
{
return a<b?a:b;
}
LL gcd(LL a,LL b)
{
return b==0?a:gcd(b,a%b);
}
LL mult_mod(LL a,LL b,LL mod)
{
LL ans=0;
while(b)
{
if(b&1)
ans=(ans+a)%mod;
a=(a<<1)%mod;
b>>=1;
}
return ans;
}
LL pow_mod(LL a,LL b,LL mod)
{
LL d=1;
a%=mod;
while(b)
{
if(b&1)
d=mult_mod(d,a,mod);
a=mult_mod(a,a,mod);
b>>=1;
}
return d%mod;
}
bool witness(LL a,LL n)
{
LL u=n-1,t=0;
while((u&1)==0)
{
u>>=1;
t++;
}
LL x,x0=pow_mod(a,u,n);
for(LL i=1; i<=t; i++)
{
x=mult_mod(x0,x0,n);
if(x==1&&x0!=1&&x0!=(n-1))
return true;
x0=x;
}
if(x!=1)
return true;
return false;
}
bool miller_rabin(LL n)
{
if(n==2) return true;
if(n<2||!(n&1)) return false;
for(int j=1; j<=8; j++)
{
LL a=rand()%(n-1)+1;
if(witness(a,n))
return false;
}
return true;
}
LL pollard_rho(LL n,LL c)
{
LL i=1,k=2,d,x=2,y=2;
while(true)
{
i++;
x=(mult_mod(x,x,n)+c)%n;
d=gcd(y-x,n);
if(d!=1&&d!=n)
return d;
if(x==y) return n;
if(i==k)
{
y=x;
k<<=1;
}
}
}
void find_fac(LL n,LL c)
{
if(miller_rabin(n)||n<=1)
{
fac[cnt++]=n;
return;
}
LL p=pollard_rho(n,c);
while(p>=n) p=pollard_rho(p,c--);
find_fac(p,c);
find_fac(n/p,c);
}
void dfs( LL step,LL num)
{
if(step==cnt||num>p)
{
if(num<=p&&num>m)
m=num;
return;
}
dfs(step+1,num*fac[step]);
dfs(step+1,num);
}
int main()
{
srand(time(NULL));
while(scanf("%I64u%I64u",&G,&L)!=EOF)
{
cnt=0;
find_fac(L/G,181);
sort(fac,fac+cnt);
LL i=0,t=0;
while(i<cnt)
{
LL ans=1,j=i;
while(j<cnt&&fac[i]==fac[j])
{
ans*=fac[i];
j++;
}
fac[t++]=ans;
i=j;
}
cnt=t,m=1,p=sqrt(0.0+(L/G));
dfs(0,1);
printf("%I64u %I64u\n",m*G,L/m);
}
return 0;
}

最新文章

  1. zookeeper源码分析之六session机制
  2. js正则表达式整理
  3. Func&lt;T&gt;、Action&lt;T&gt; 的区别于说明
  4. curl详解
  5. select元素javascript常用操作 转
  6. javascript去掉字符串前后空格
  7. ASP.NET GridView HyperLinkField传值和取值【转】
  8. vector &amp; array
  9. mysql同时向一个表中插入多条数据问题!!见详细
  10. OpenGL绘制自由落体小球
  11. ComboBox值排序
  12. 简述TCP的三次握手过程
  13. RSA加密传输代码示例
  14. imageview设置图片时超长超大图片超出限制(OpenGLRenderer: Bitmap too large to be uploaded into a texture (996x9116, max=4096x4096))
  15. ORACL内部异常:
  16. WRI$_ADV_OBJECTS表过大,导致PDB的SYSAUX表空间不足
  17. scrollView截取指定区域的图片
  18. 如何使用CBO,CBO与RULE的区别
  19. 神经网络优化方法总结:SGD,Momentum,AdaGrad,RMSProp,Adam
  20. VisualStudio: Vistual Studio XML 智能提示(转载)

热门文章

  1. 洛谷 P2984 [USACO10FEB]给巧克力Chocolate Giving
  2. 添加/删除 windows下Git右键菜单
  3. MIPS程序设计实例
  4. 【page-monitor 前端自动化 上篇】初步调研
  5. shell脚本,实现奇数行等于偶数行。
  6. Spring框架 全注解annotation不使用配置文件(SpringConfiguration.java类代替) 补充 xml配置文件没有提示解决
  7. POJ 2255 Tree Recovery——二叉树的前序遍历、后序遍历、中序遍历规则(递归)
  8. sql server存储过程修改,存储到mysql笔记
  9. 七:MYSQL之常用操作符
  10. react 列表渲染