博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
ZOJ 2562 More Divisors(高合成数)
阅读量:6719 次
发布时间:2019-06-25

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

ZOJ 2562 More Divisors(高合成数)

ACM

题目地址:

题意: 

求小于n的最大的高合成数,高合成数指一类整数,不论什么比它小的自然数的因子数目均比这个数的因子数目少。

分析: 

网上都叫它反素数,事实上我查了一下,翻素数应该是正着写倒着写都是素数的素数。这个应该叫高合成数,见

高合成数有下面特征: 

where p1<p2<<pk are prime, and the exponents ci are positive integers. 
Any factor of n must have the same or lesser multiplicity in each prime: 
p1^d1×p2^d2××pk^dk0dici0<ik 
所以用回溯枚举。

代码

/**  Author:      illuz 
* Blog: http://blog.csdn.net/hcbbt* File: 2562.cpp* Create Date: 2014-08-06 20:45:53* Descripton: Highly Composite Number*/#include
#include
#include
#include
using namespace std;#define repf(i,a,b) for(int i=(a);i<=(b);i++)typedef long long ll;const int M = 1000;ll n;ll bestNum;ll bestSum;ll hcm[M][2];ll prim[] = {2, 3, 5, 7, 11, 13, 17, 19, 23, 29, 31, 37, 41, 43, 47, 53, 59, 61, 67}; // current is num, use the prim[k], sum of divisors, the limit of prim[k] you can usevoid getNum(ll num, int k, ll sum, int limit) { if (sum > bestSum) { bestSum = sum; bestNum = num; } else if (sum == bestSum && num < bestNum) { bestNum = num; } ll p = prim[k]; for (int i = 1; i <= limit; i++, p *= prim[k]) { // use i prim[k]s if (num * p > n) break; getNum(num *= prim[k], k + 1, sum * (i + 1), i); }}// clac log2(n)int log2(ll n) { int ret = 0; ll p = 1; while (p < n) { p <<= 1; ret++; } return ret;}// return the number of Highly Composite Number in [1, n]// and save the HCM in hcm[][2]int gethcm() { int ret = 0; n = 500000; // [1, n] while (n > 0) { bestNum = 1; bestSum = 1; getNum(1, 0, 1, log2(n)); cout << bestNum << ' ' << bestSum << endl; hcm[ret][0] = bestNum; hcm[ret][1] = bestSum; n = bestNum - 1; ret++; } return ret;}int main() { while (cin >> n) { bestNum = 1; bestSum = 1; getNum(1, 0, 1, 50); cout << bestNum << endl; }}

你可能感兴趣的文章
SQL学习笔记6
查看>>
Jmeter初步使用三--使用jmeter自身录制脚本
查看>>
docker 安装 redis
查看>>
HDU2203:亲和串(KMP)
查看>>
常见shell操作
查看>>
iOS应用程序生命周期(前后台切换,应用的各种状态)详解
查看>>
android 动画
查看>>
javascript 的数值转换
查看>>
.Net转Java自学之路—SSH框架篇一
查看>>
Factom(公证通)--基于区块链的存证系统
查看>>
.net对html的抓取
查看>>
BZOJ2738矩阵乘法——整体二分+二维树状数组
查看>>
2017开发学习计划
查看>>
spring注解
查看>>
Python 函数装饰器和闭包
查看>>
ImageResizer为图片添加水印
查看>>
12.21站立会议
查看>>
POJ-3624 01背包入门
查看>>
session cookie
查看>>
odoo开发历史订单需求整体思路
查看>>