poj2429 大数分解+dfs
//Accepted 172 KB 172 ms
//该程序为随机性算法,运行时间不定
#include <cstdio>
#include <cstring>
#include <iostream>
#include <ctime>
#include <algorithm>
using namespace std;
],factor_top=-;
//gcd
long long gcd(long long a,long long b)
{
) return a;
return gcd(b,a%b);
}
//a*b%n n<2^62
long long mult_mod(long long a,long long b,long long n)
{
;
while (b)
{
)
{
res+=exp;
if (res>n) res-=n;
}
exp<<=;
if (exp>n) exp-=n;
b>>=;
}
return res;
}
//return a^b%n
long long exp_mod(long long a,long long b,long long n)
{
,exp=a%n;
)
{
)
{
res=mult_mod(res,exp,n);
}
exp=mult_mod(exp,exp,n);
b>>=;
}
return res;
}
//miller_rabin 算法进行素数判定
//判断次数times次 一般取times=10
//return true 则n为素数
bool miller_rabin(long long n,long long times)
{
) return true;
|| !(n&)) return false;
,x,y;
;
==)
{
t++;
u/=;
}
srand(time());
;i<times;i++)
{
a=rand()%(n-)+;
x=exp_mod(a,u,n);
;j<t;j++)
{
y=mult_mod(x,x,n);
&& x!= && x!=n-)
return false; //not prime
x=y;
}
) return false;
}
return true;
}
//pollar_rho 求n的一个质因子
//c 为测试函数中的常数
long long pollard_rho(long long n,int c)
{
,k=;
srand(time());
x=rand()%(n-)+;
y=x;
while (true)
{
i++;
x=(mult_mod(x,x,n)+c)%n;
d=gcd(y-x,n);
&& d<n) return d;
if (y==x) return n;
if (i==k)
{
y=x;
k<<=;
}
}
}
//找出n的所用质因子
void findFactor(long long n,int c)
{
) return ;
))
{
factor[++factor_top]=n;
return ;
}
long long p=n;
while (p>=n)
{
p=pollard_rho(p,c--);
}
findFactor(p,c);
findFactor(n/p,c);
}
];
int m;
int cmp(long long a,long long b)
{
return a>b;
}
void slove()
{
sort(factor,factor+factor_top+,cmp);
m=;
a[]=factor[];
;i<factor_top;i++)
{
])
{
a[m]*=factor[i];
}
else
{
m++;
a[m]=factor[i+];
}
}
}
long long minx,ans;
void dfs(int s,long long num,long long t)
{
)
{
|| (num+t/num<minx))
{
minx=num+t/num;
ans=num;
}
return ;
}
dfs(s+,a[s]*num,t);
dfs(s+,num,t);
}
int main()
{
__int64 s,t,n;
while (scanf("%I64d%I64d",&s,&t)!=EOF)
{
n=t/s;
if (s==t)
{
printf("%I64d %I64d\n",s,t);
continue;
}
//printf("%I64d\n",gcd(t,s));
factor_top=-;
findFactor(n,);
//printf("findFactor()\n");
m=;
slove();
//printf("slove()\n");
minx=-;
dfs(,,n);
//printf("dfs()\n");
if (ans>n/ans) ans=n/ans;
printf("%I64d %I64d\n",ans*s,n/ans*s);
}
;
}
poj2429 大数分解+dfs的更多相关文章
- poj1181 大数分解
//Accepted 164 KB 422 ms //类似poj2429 大数分解 #include <cstdio> #include <cstring> #include ...
- HDU4344(大数分解)
题目:Mark the Rope 题意就是给一个数,然后求这个数的所有因子中组成的最大的一个子集,其中1和本身除外,使得在这个子集中元素两两互素,求最大子集的元素个 数,并且求出和最大的值. 找规律就 ...
- poj 1811 随机素数和大数分解(模板)
Sample Input 2 5 10 Sample Output Prime 2 模板学习: 判断是否是素数,数据很大,所以用miller,不是的话再用pollard rho分解 miller : ...
- Pollard_Rho大数分解模板题 pku-2191
题意:给你一个数n, 定义m=2k-1, {k|1<=k<=n},并且 k为素数; 当m为合数时,求分解为质因数,输出格式如下:47 * 178481 = 8388607 = ( ...
- POJ 2429 GCD & LCM Inverse (Pollard rho整数分解+dfs枚举)
题意:给出a和b的gcd和lcm,让你求a和b.按升序输出a和b.若有多组满足条件的a和b,那么输出a+b最小的.思路:lcm=a*b/gcd lcm/gcd=a/gcd*b/gcd 可知a/gc ...
- poj 2429 Pollard_rho大数分解
先对lcm/gcd进行分解,问题转变为从因子中选出一些数相乘,剩下的数也相乘,要求和最小. 这里能够直接搜索,注意一个问题,因为同样因子不能分配给两边(会改变gcd)所以能够将同样因子合并,这种话,搜 ...
- Light OJ 1341 Aladdin and the Flying Carpet Pollard_rho整数分解+DFS
进入a b 多少努力p, q 使p*q == a && p < q && p >= b 直接大整数分解 然后dfs所有可能的解决方案劫持 #include ...
- 1400 序列分解(dfs)
1400 序列分解 基准时间限制:1 秒 空间限制:131072 KB 分值: 40 难度:4级算法题 小刀和大刀是双胞胎兄弟.今天他们玩一个有意思的游戏. 大刀给小刀准备了一个长度为n的整数序列.小 ...
- poj 1811 大数分解
模板 #include<stdio.h> #include<string.h> #include<stdlib.h> #include<time.h> ...
随机推荐
- Linux安装多个Python版本
服务器上的Python版本太老了,需要安装一个新的Python版本,才能跑我的代码.因为环境的需要,但是又不能卸载老的版本,所以安装一个新的,使用软链来进行升级. 使用系统自带的yum,apt-get ...
- android GC内存回收小析
由于时间问题,简单的谈谈自己的理解. 大家都知道,在android开发中,不需要自己去管理,有垃圾回收机制会自动帮我们去回收 没有被引用到的对象. 那垃圾回收机制到底是怎样的呢?下面列出本人的一些理解 ...
- $('#checkbox').attr('checked'); 返回的是checked或者是undefined解决办法
$('#checkbox').attr('checked'); 返回的是checked或者是undefined解决办法 <input type='checkbox' id='cb'/> ...
- IO流 总结三
编码:字符串变成字节数组. 解码:字节数组变成字符串 String --> byte[]; str.getBytes(); byte --> String: new String(byt ...
- Testin
http://www.testin.cn/ http://news.ccidnet.com/art/66/20150416/5815927_1.html 百度百科上面的 Testin是全球最大的移 ...
- C语言指针(一)
一.指针 定义指针变量 指针指向的数据类型 *指针变量名称; 例: int *p; *作用: 1.在定义变量的时候 * 是一个类型说明符,说明定义的这个变量是一个指针变量 2.在不是定义变量的时候 * ...
- Spring源码学习-PropertyPlaceholderHelper
转载:http://my.oschina.net/ydsakyclguozi/blog/465526 1. CustomPropertyConfigurer.java package property ...
- Xmanager如何连接图形化界面
1.编辑gnome配置文件vim /etc/gdm/custom.conf # GDM configuration storage [daemon]RemoteGreeter= /usr/libexe ...
- oracle遇到死锁杀进程
java程序操作数据库的时候,遇到死锁:java.sql.SQLException: ORA-00060: 等待资源时检测到死锁 解决步骤: 1.找到死锁的oralce对象(表): select ob ...
- HTTPS是如何保证连接安全,你知道吗?
HTTPS协议的工作原理是什么?”这是我在数天前工作项目中需要解决的问题. 作为一名Web开发者,我当然知道 HTTPS 协议是保障用户敏感数据的好办法,但并不知道这种协议的内在工作机制. 它怎么保护 ...