题意:给定n求,有n个因子的最小正整数。

题解:水题,zcr都会,我就不说什么了。

  因数个数球求法应该知道,将m分解质因数,然后发现 a1^p1*a2^p2....an^pn这样一个式子,

  (1+p1)*(1+p2)*...=n,然后用小的质数填坑。

 #include <bits/stdc++.h>
using namespace std; int pri[] = {,,,,,,,,,,,,,,,,};
int n, ans[], res[], tmp[];
double lg[], mn=DBL_MAX; void input()
{
scanf("%d", &n);
for(int i=; i<=; i++) lg[i] = log(pri[i]);
} void dfs(double x, int y, int z){//现在的数是e^x,还剩下y个因子,选到第z个质数
if(x >= mn) return;
if(y == ){
mn = x;
memset(res, , sizeof(res));
for(int i=; i<=z-;i++) res[i]=tmp[i];
return;
}
if(z>) return;
for(int i = ; (i+)*(i+)<=y; i++){
if(y%(i+)==)
{
if(i != ){
tmp[z] = i;
dfs(x+lg[z]*i, y/(i+), z+);
}
if((i+)*(i+)!=y){
tmp[z] = y/(i+)-;
dfs(x+lg[z]*(y/(i+)-), i+, z+);
}
}
}
} void work()
{
dfs(, n, );
} void output()
{
ans[]=ans[]=;
for(int i=;i<=;i++){
for(;res[i]>;res[i]--){
for(int j=;j<=ans[];j++) ans[j]*=pri[i];
for(int j=;j<=ans[];j++) ans[j+]+=ans[j]/, ans[j]%=;
if(ans[ans[]+]!=) ans[]++;
while(ans[ans[]]/!=){
ans[ans[]+] += ans[ans[]]/;
ans[ans[]] %= ;
++ans[];
}
}
}
for(int i = ans[]; i>=; i--){
printf("%d", ans[i]);
}
printf("\n");
} int main()
{
input();
work();
output();
return ;
}

BZOJ 1225: [HNOI2001] 求正整数 高精度+搜索+质数的更多相关文章

  1. BZOJ 1225: [HNOI2001] 求正整数( dfs + 高精度 )

    15 < log250000 < 16, 所以不会选超过16个质数, 然后暴力去跑dfs, 高精度计算最后答案.. ------------------------------------ ...

  2. 【BZOJ】1225: [HNOI2001] 求正整数

    http://www.lydsy.com/JudgeOnline/problem.php?id=1225 题意:给一个数n,求一个最小的有n个约数的正整数.(n<=50000) #include ...

  3. bzoj1225 [HNOI2001] 求正整数

    1225: [HNOI2001] 求正整数 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 762  Solved: 313[Submit][Statu ...

  4. 高精度+搜索+质数 BZOJ1225 [HNOI2001] 求正整数

    // 高精度+搜索+质数 BZOJ1225 [HNOI2001] 求正整数 // 思路: // http://blog.csdn.net/huzecong/article/details/847868 ...

  5. luogu P1128 [HNOI2001]求正整数 dp 高精度

    LINK:求正整数 比较难的高精度. 容易想到贪心不过这个贪心的策略大多都能找到反例. 考虑dp. f[i][j]表示前i个质数此时n的值为j的最小的答案. 利用高精度dp不太现实.就算上FFT也会T ...

  6. [HNOI2001]求正整数

    题目描述 对于任意输入的正整数n,请编程求出具有n个不同因子的最小正整数m. 例如:n=4,则m=6,因为6有4个不同整数因子1,2,3,6:而且是最小的有4个因子的整数. 输入输出格式 输入格式: ...

  7. [HNOI2001] 求正整数 - 背包dp,数论

    对于任意输入的正整数n,请编程求出具有n个不同因子的最小正整数m. Solution (乍一看很简单却搞了好久?我真是太菜了) 根据因子个数计算公式 若 \(m = \prod p_i^{q_i}\) ...

  8. P1128 [HNOI2001]求正整数

    传送门 rqy是我们的红太阳没有它我们就会死 可以考虑dp,设\(dp[i][j]\)表示只包含前\(j\)个质数的数中,因子个数为\(i\)的数的最小值是多少,那么有转移方程 \[f[i][j]=m ...

  9. 实验一:实现求正整数1-N之间所有质数的功能,并进行测试。

    实验一 Java开发环境的熟悉(Linux + Eclipse) 实验内容 1.使用JDK编译.运行简单的Java程序: 2.使用Eclipse 编辑.编译.运行.调试Java程序. 命令行下的程序开 ...

随机推荐

  1. Android 线程池系列教程(1)目录

    Sending Operations to Multiple Threads 1.Dependencies and prerequisites Android 3.0 (API Level 11) o ...

  2. laravel 淘宝 NPM 镜像

    淘宝 NPM 镜像:http://npm.taobao.org/ 这是一个完整 npmjs.org 镜像,你可以用此代替官方版本(只读),同步频率目前为 10分钟 一次以保证尽量与官方服务同步. 当前 ...

  3. c#中stringbuilder的方法总结

    String 对象是不可改变的.每次使用 System.String 类中的方法之一时,都要在内存中创建一个新的字符串对象,这就需要为该新对象分配新的空间.在需要对字符串执行重复修改的情况下,与创建新 ...

  4. 自定义button上传按钮

    <div class="upload_files"> <input type="file" class="upload_icon&q ...

  5. spring 配置 shiro rememberMe

    1.shiro 提供记住我的功能,当将form表单中name="rememberMe" 的value设为true或者登陆的token中.token.setRememberMe(tr ...

  6. Asp.Net 设计模式 之 “工厂方法”即利用 接口 实现的抽象工厂

    主要改动部分: /// <summary>    /// 6.创建工厂方法模式(抽象工厂:接口)    /// </summary>    interface IFactory ...

  7. BotFramework学习-01

    微软在Build2016大会上表示,未来将是一个充满聊天机器人的世界,为此他们推出了微软Bot Framework,能够允许任何人制作自己的聊天机器人,微软则提供“cognitive microser ...

  8. 整合Activiti Modeler到业务系统(或BPM平台)

    http://www.kafeitu.me/activiti/2013/03/10/integrate-activiti-modeler.html 1. 为什么要整合 Activiti 5.10版本把 ...

  9. ASP.NET自学之路(转载)

    第一步 掌握一门NET面向对象语言,C#或VB.NET 我强烈反对在没系统学过一门面向对象(OO)语言的前提下去学ASP.NET. ASP.NET是一个全面向对象的技术,不懂OO,那绝对学不下去! 第 ...

  10. Kotlin – CharSequence IsNullOrBlank() vs IsNullOrEmpty()

    本文摘自:http://blog.farifam.com/2018/01/28/kotlin-charsequence-isnullorblank-vs-isnullorempty/ Koltin p ...