hdu4542 && ZOJ2562(反素数)
反素数:
对于任何正整数,其约数个数记为
,例如
,如果某个正整数
满足:对任意的正整
数,都有
,那么称
为反素数。
有两个特点:
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(反素数)的更多相关文章
- zoj2562 反素数
/* 这题1 <= n <= 1016,暴力肯定是TLM,所以看了大牛求解小于N的反素数的算法,思路大致是这样的: 性质1:一个反素数的质因子一定是从2开始的若干个连续质数. 因此可以枚举 ...
- ZOJ- 2562 反素数使用
借用了下东北师大ACM的反素数模版. 本来我是在刷线段树的,有一题碰到了反素数,所以学了一下..有反素数的存在,使得一个x ,使得x的约数个数,在1 到 x的所有数里面,是最大的. 这里面还涉及安叔那 ...
- 【zoj2562】反素数
题意:给定一个数N,求小于等于N的所有数当中,约数最多的一个数,如果存在多个这样的数,输出其中最小的一个.(1 <= n <= 10^16) 题目:http://acm.hust.edu. ...
- ZOJ-2562 More Divisors 反素数
题意:给定一个数N,求小于等于N的所有数当中,约数最多的一个数,如果存在多个这样的数,输出其中最大的一个. 分析:反素数定义:对于任何正整数x,其约数的个数记做g(x).例如g(1)=1,g(6)=4 ...
- zoj2562:搜索+数论(反素数)
题目大意:求n以内因子数量最多的数 n的范围为1e16 其实相当于求n以内最大的反素数... 由素数中的 算数基本原理 设d(a)为a的正因子的个数,则 d(n)=(a1+1)(a2+1)..... ...
- poj 2886 线段树的更新+反素数
Who Gets the Most Candies? Time Limit: 5000 MS Memory Limit: 0 KB 64-bit integer IO format: %I64d , ...
- 【POJ2886】Who Gets the Most Candies?-线段树+反素数
Time Limit: 5000MS Memory Limit: 131072K Case Time Limit: 2000MS Description N children are sitting ...
- Prime & 反素数plus
题意: 求因数个数为n的最小正整数k. n<=10^9输出其唯一分解形式 SOL: 模拟题,一眼看过去有点惊讶...这不是我刚看过的反素数吗... 咦数据怎么这么大,恩搞个高精吧... 于是T了 ...
- BZOJ 1053 & 反素数
题意: 反素数,膜一篇GOD's Blog...http://blog.csdn.net/ACdreamers/article/details/25049767 此文一出,无与争锋... CODE: ...
随机推荐
- PTA題目的處理(一)
**題目1:A乘B** **實驗代碼** #include <stdio.h> #include <stdlib.h> int main() { signed int a,b; ...
- 2018c语言第1次作业
6-1 计算两数的和与差 1.设计思路 (1)主要描述题目算法 第一步:把两个数的加减法分别赋给psum和pdiff. 第二步:通过psum和pdiff的地址把值传回主函数. (2)流程图.(无) 2 ...
- 团队作业4——第一次项目冲刺(Alpha版本)11.18
a. 提供当天站立式会议照片一张 举行站立式会议,讨论项目安排: 整理各自的任务汇报: 全分享遇到的困难一起讨论: 讨论接下来的计划: b. 每个人的工作 (有work item 的ID) 1.前两天 ...
- python 常用算法学习(2)
一,算法定义 算法(Algorithm)是指解题方案的准确而完整的描述,是一系列解决问题的清晰指令,算法代表着用系统的方法描述解决问题的策略机制.也就是说,能够对一定规范的输入,在有限时间内获得所要求 ...
- Python之旅.第四章.模块与包.总结(未完待遇)
一.模块 模块: 一系列功能的集合体,在python中一个py文件就是一个模块,模块名就是py文件的文件名: 模块的好处: 1.减少重复的代码 2.拿来主义 定义模块: 就是创建一个py文件: 使用模 ...
- Web Api HttpWebRequest 请求 Api 及 异常处理
HttpWebRequest request = WebRequest.CreateHttp(url); request.Method = "post"; request.Head ...
- api-gateway实践(15)3.6JL分支和3.7并行改造需求
一.名称改为"API网关" --哪个地方的名称?二.开发者视图中,API网关显示两个视图. 1. 服务分类视图:支持按照业务分为多个类别,分类方式参照应用服务化的分类:人像比对.自 ...
- hadoop2.7.3+spark2.1.0+scala2.12.1环境搭建(2)安装hadoop
一.依赖安装 安装JDK 二.文件准备 hadoop-2.7.3.tar.gz 2.2 下载地址 http://hadoop.apache.org/releases.html 三.工具准备 3.1 X ...
- ZOJ-2913 Bus Pass---BFS进阶版
题目链接: https://vjudge.net/problem/ZOJ-2913 题目大意: 问哪个区域到公交路线上所有区域的最大距离最小 思路: 这里要求出到底是哪个区域到某些指定区域的最大距离最 ...
- java 面向对象编程。。。。
经过一周的学习(java),总结了许多,对java的理解,java的类型,运用,安装,基础语法,变量,常量,表达式,语句 java从C语言中继承了大量语言特性.java面向对象编程的基本特征,包括继承 ...