HAOI2007反素数
1053: [HAOI2007]反素数ant
Time Limit: 10 Sec  Memory Limit: 162 MB
Submit: 1346  Solved: 732
[Submit][Status]
Description
对于任何正整数x,其约数的个数记作g(x)。例如g(1)=1、g(6)=4。
  如果某个正整数x满足:g(x)>g(i) 0<i<x,则称x为反质数。例如,整数1,2,4,6等都是反质数。
现在给定一个数N,你能求出不超过N的最大的反质数么?
Input
一个数N(1<=N<=2,000,000,000)。
Output
不超过N的最大的反质数。
Sample Input
Sample Output
HINT
题解:
先筛质数,首先我们知道分解质因数后 i=p1^s1*p2^s2...pk^sk;那么g(i)=(s1+1)*(s2+1)*(s3+1)...(sk+1)
所以我们枚举质数的指数,直接枚举不太好
我们可以发现一个性质,反质数的各个指数一定是不上升的,因为上升的情况我们可以翻转上升的那一段,使得g不变i变小,这个时候搜索就无压力了
一开始没注意,其实前十个质数相乘已经很大了,我们只要前十个就行了
还有就是,要记录现在ans的g,如果有一样的g,要选小的那个
代码:
const p:array[..] of longint=(,,,,,,,,,);
var n,ans,num:int64;
procedure dfs(x,y,z,k:int64);
var i:longint;
begin
if (num<k) or ((num=k) and (x<ans)) then
begin
ans:=x;num:=k;
end;
for i:= to y do
begin
x:=x*p[z];
if x>n then exit;
dfs(x,i,z+,k*(i+));
end;
end;
procedure main;
begin
readln(n);
dfs(,n,,);
writeln(ans);
end;
begin
main;
end.
HAOI2007反素数的更多相关文章
- BZOJ 1053: [HAOI2007]反素数ant dfs
		
1053: [HAOI2007]反素数ant 题目连接: http://www.lydsy.com/JudgeOnline/problem.php?id=1053 Description 对于任何正整 ...
 - bzoj1053: [HAOI2007]反素数ant
		
51nod有一道类似的题...我至今仍然不会写暴搜!!! #include<cstdio> #include<cstring> #include<iostream> ...
 - 【BZOJ】1053: [HAOI2007]反素数ant
		
1053: [HAOI2007]反素数ant Description: g(x)表示x的约数个数,反素数:对于任意的i (i < x),均有g(i) < g(x),则x为反素数:现在输入不 ...
 - bzoj 1053: [HAOI2007]反素数ant 搜索
		
1053: [HAOI2007]反素数ant Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 1497 Solved: 821[Submit][Sta ...
 - BZOJ 1053 [HAOI2007]反素数ant
		
1053: [HAOI2007]反素数ant Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 1948 Solved: 1094[Submit][St ...
 - 1053: [HAOI2007]反素数ant
		
1053: [HAOI2007]反素数ant Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 3480 Solved: 2036[Submit][St ...
 - 【BZOJ1053】[HAOI2007]反素数(搜索)
		
[BZOJ1053][HAOI2007]反素数(搜索) 题面 BZOJ 洛谷 题解 大力猜一下用不了几个质因子,那么随便爆搜一下就好了. #include<iostream> #inclu ...
 - 【BZOJ1053】[HAOI2007]反素数
		
[BZOJ1053][HAOI2007]反素数 题面 bzoj 洛谷 题解 可以从反素数的定义看出小于等于\(x\)的最大反素数一定是约数个数最多且最小的那个 可以枚举所有的质因数来求反素数,但还是跑 ...
 - 【BZOJ 1053】 1053: [HAOI2007]反素数ant (反素数)
		
1053: [HAOI2007]反素数ant Description 对于任何正整数x,其约数的个数记作g(x).例如g(1)=1.g(6)=4.如果某个正整数x满足:g(x)>g(i) 0&l ...
 
随机推荐
- tortoiseGit的SHH秘钥设置
			
tortoiseGit如果安装时使用默认的putty方式,因为putty的秘钥格式和SSH的不一样,所以要使用自带的工具重新生成一次秘钥. 具体的方式是:用puttyGen工具来生成公钥和秘钥,公钥( ...
 - Python生成验证码
			
#!/usr/bin/env python #coding:utf8 import random #方法1: str_code='zxcvbnmasdfghjklqwertyuiopZXCVBNMAS ...
 - Security log is full,only administrator can log on to fix the problem(安全日志满了)
			
When you login the system and see this error “Security log on this system is full,only administrato ...
 - PAT乙级真题1006. 换个格式输出整数 (15)(解题)
			
原题: 让我们用字母B来表示“百”.字母S表示“十”,用“12...n”来表示个位数字n(<10),换个格式来输出任一个不超过3位的正整数.例如234应该被输出为BBSSS1234,因为它有2个 ...
 - 如何查看windows操作系统当前使用的字符集
			
如何查看windows操作系统当前使用的字符集 Chcp 显示活动控制台代码页数量,或更改该控制台的活动控制台代码页.如果在没有参数的情况下使用,则 chcp 显示活动控制台代码页的数量. 语法 ch ...
 - dive into python 读笔(2)
			
chapter 4 自省, summary: # 用可选和命名参数定义和调用函数 # 用 str 强制转换任意值为字符串形式 # 用 getattr 动态得到函数和其它属性的引用 # 扩展列表解析语法 ...
 - 1057: [ZJOI2007]棋盘制作 - BZOJ
			
Description 国际象棋是世界上最古老的博弈游戏之一,和中国的围棋.象棋以及日本的将棋同享盛名.据说国际象棋起源于易经的思想,棋盘是一个8*8大小的黑白相间的方阵,对应八八六十四卦,黑白对应阴 ...
 - js按钮点击展开收起
			
$('.tab').click(function(){ var index = $('.tab').index(this), //缓存第一次点击的li的索引值 ele = $(this).find(' ...
 - 【莫队】bzoj 3781,bzoj 2038,bzoj 3289
			
好像又有一个星期没更博客了.. 最近疯狂考试...唯一有点收获的就是学会了莫队这种神奇的算法.. 听起来很难..其实是一个很简单的东西.. 就是在区间处理问题时对于一个待求区间[L',R']通过之前求 ...
 - C++11新特性:Lambda函数(匿名函数)
			
声明:本文参考了Alex Allain的文章http://www.cprogramming.com/c++11/c++11-lambda-closures.html 加入了自己的理解,不是简单的翻译 ...