反素数:

对于任何正整数,其约数个数记为,例如,如果某个正整数满足:对任意的正整

,都有,那么称为反素数。

有两个特点:

1.一个反素数的质因子必是从2开始的质数

2.如果,那么必有

最常见的问题如下:

(1)给定一个数,求一个最小的正整数,使得的约数个数为

(2)求出中约数个数最多的这个数

即是通过搜索建立一个搜索树,递归出合适的所有的情况,再加上剪枝。

ZOJ2562

题意:

给定一个数N,求小于等于N的所有数当中,约数最多的一个数,如果存在多个这样的数,输出其中最大的一个。

#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
#include <cmath>
#include <time.h>
#define N 10100
typedef long long ll;
using namespace std;
ll maxs,allnum;
ll n;
int prim[16] = {1,2,3,5,7,11,13,17,19,23,29,31,37,41,43,47}; void dfs(ll num,ll k,ll sum,ll limit)
{
if(sum > maxs)
{
maxs = sum;
allnum = num;
} if(sum == maxs && allnum > num )
allnum = num;
ll temp = num;
if(k > 15)
return ;
for(int i= 1;i <= limit;i++)
{
if(temp*prim[k] > n)
break;
dfs(temp*= prim[k],k+1,sum*(i+1),i);
}
} int main()
{
while(cin>>n)
{
maxs = 0;
allnum = n;
dfs(1,1,1,50);
cout<<allnum<<endl;
}
return 0;
}</span>

  

hdu 4542

题意:
给出一个数K,和两个操作,

如果操作是0,就求出一个最小的正整数X,满足X的约数个数为K,

如果操作是1,就求出一个最小的X,满足X的约数个数为X-K。

d来先处理成与i互质的个数。由于d[i] < i,将其处理成d[i]=x,表示有x 个非约数的为i

#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
#include <cmath>
#include <time.h>
#define N 10100
typedef long long ll;
using namespace std;
ll INF = ((ll)1<<62)+1;
int d[50005];
ll maxs,allnum;
ll n,type;
int prim[16] = {2,3,5,7,11,13,17,19,23,29,31,37,41,43,47,53}; void ini()
{
for(int i = 1; i <= 50005; i++) d[i] = i;
for(int i = 1; i <= 50005; i++)
{
for(int j = i; j <= 50005; j+=i) d[j]--; //滚动数组的形式
if(!d[d[i]]) d[d[i]] = i;
d[i] = 0;
}
}
//如果d[k]=0,表示小于i的所有数中,没有刚好有k个互质数的数
//故将d[k]=i,表示刚好有k个与i互质的数个数最小为i
//d[i] = 0标记刚好有k个互质数的数没有 void dfs(ll sum,ll k,ll num,ll limit)
{
if(num > n) return ;
if(sum < maxs && num == n) maxs = sum;
ll temp = sum;
for(int i= 1; i <= limit; i++)
{
if(num*(i+1) > n || maxs/prim[k] < temp) break; //大于n或者结果大于maxs,不需再考虑
temp *= prim[k];
if(n % (num*(i+1)) == 0)
dfs(temp,k+1,num*(i+1),i);
}
} int main()
{
int T;
int tt = 1;
ini();
scanf("%d",&T);
while(T--)
{
scanf("%I64d%I64d",&type,&n);
if(type)
maxs = d[n];
else
{
maxs = INF;
dfs(1,0,1,100); //最初这100是50,,一直错,估计是太小
}
printf("Case %d: ",tt++);
if(maxs == 0)
puts("Illegal");
else if(maxs >= INF)
puts("INF");
else
printf("%I64d\n",maxs);
}
return 0;
}

  

hdu4542 && ZOJ2562(反素数)的更多相关文章

  1. zoj2562 反素数

    /* 这题1 <= n <= 1016,暴力肯定是TLM,所以看了大牛求解小于N的反素数的算法,思路大致是这样的: 性质1:一个反素数的质因子一定是从2开始的若干个连续质数. 因此可以枚举 ...

  2. ZOJ- 2562 反素数使用

    借用了下东北师大ACM的反素数模版. 本来我是在刷线段树的,有一题碰到了反素数,所以学了一下..有反素数的存在,使得一个x ,使得x的约数个数,在1 到 x的所有数里面,是最大的. 这里面还涉及安叔那 ...

  3. 【zoj2562】反素数

    题意:给定一个数N,求小于等于N的所有数当中,约数最多的一个数,如果存在多个这样的数,输出其中最小的一个.(1 <= n <= 10^16) 题目:http://acm.hust.edu. ...

  4. ZOJ-2562 More Divisors 反素数

    题意:给定一个数N,求小于等于N的所有数当中,约数最多的一个数,如果存在多个这样的数,输出其中最大的一个. 分析:反素数定义:对于任何正整数x,其约数的个数记做g(x).例如g(1)=1,g(6)=4 ...

  5. zoj2562:搜索+数论(反素数)

    题目大意:求n以内因子数量最多的数  n的范围为1e16 其实相当于求n以内最大的反素数... 由素数中的 算数基本原理 设d(a)为a的正因子的个数,则 d(n)=(a1+1)(a2+1)..... ...

  6. poj 2886 线段树的更新+反素数

    Who Gets the Most Candies? Time Limit: 5000 MS Memory Limit: 0 KB 64-bit integer IO format: %I64d , ...

  7. 【POJ2886】Who Gets the Most Candies?-线段树+反素数

    Time Limit: 5000MS Memory Limit: 131072K Case Time Limit: 2000MS Description N children are sitting ...

  8. Prime & 反素数plus

    题意: 求因数个数为n的最小正整数k. n<=10^9输出其唯一分解形式 SOL: 模拟题,一眼看过去有点惊讶...这不是我刚看过的反素数吗... 咦数据怎么这么大,恩搞个高精吧... 于是T了 ...

  9. BZOJ 1053 & 反素数

    题意: 反素数,膜一篇GOD's Blog...http://blog.csdn.net/ACdreamers/article/details/25049767 此文一出,无与争锋... CODE: ...

随机推荐

  1. 20145237 《Java程序设计》第2周学习总结

    教材学习内容总结 本周我学习了java的基础语法.分为类型.变量与运算符,流程控制. 一.类型:1.Java可以区分为基本类型和类类型.类类型也称作参考类型.2.Java中基本类型主要是整数.字节.浮 ...

  2. jQuery 文档操作之prepend() 和prependTo()方法.

    //prepend() $("#btnpre").click(function(){ //该方法在被选元素的开头(仍位于内部)插入指定内容. $("div"). ...

  3. Windows 的Apache支持SSI配置

    配置SSI什么是shtml? 使用SSI(Server Side Include)的html文件扩展名,SSI(Server Side Include),通常称为"服务器端嵌入"或 ...

  4. Linux入门(1)_VMware和系统分区和系统安装和远程登陆管理

    1 VMware的安装和使用 注意有 快照 和 克隆 的功能. 快照相当于建立一个 系统还原点, 可以随时恢复到原来状态. 克隆功能可以复制一个和当前一样的系统,并可以选择链接安装,只使用很少的空间就 ...

  5. zookeeper入门系列 : 分布式事务

    上一章我们了解了zookeeper到底是什么,这一章重点来看zookeeper当初到底面临什么问题?而zookeeper又是如何解决这些问题的? 实际上zookeeper主要就是解决分布式环境下的一致 ...

  6. Mego开发文档 - 基本保存操作

    基本保存操作 在Mego中没有更改跟踪,也就是说所有的新增.更新及删除都需要开发者自行判断.Mego会最为实际的将各个数据操作提交给数据库并执行. 添加数据 using (var db = new O ...

  7. Angular 学习笔记 ( 链接服务器 )

    ng 是做前端开发的, 所以通常我们会配上一个 API server. 本地调试时通常使用 proxy https://github.com/angular/angular-cli/blob/mast ...

  8. api-gateway实践(06)新服务网关 - 请求监控

    一.实时监控 用户点击服务实例,系统显示服务实例-version下的api列表, 用户点击某个api的如下两个图标 1.API请求次数监控 横轴:时间,粒度为分钟 纵轴:请求访问次数 展示:失败数(红 ...

  9. SpringMvc(4-1)Spring MVC 中的 forward 和 redirect

    Spring MVC 中,我们在返回逻辑视图时,框架会通过 viewResolver 来解析得到具体的 View,然后向浏览器渲染.通过配置,我们配置某个 ViewResolver 如下: <b ...

  10. maven常见问题处理(3-2)maven打包时跳过测试的几个方法

    运行mvn install时跳过Test方法一:<project> [...] <build> <plugins> <plugin> <group ...