HDU4542 小明系列故事——未知剩余系
大赞的数论题;
大致思路:
对于TYPE=1的情况,认为 X 中有 X-K个约数,求最小的X,X-K>0 那么化为B+K的约数为B,
我们知道(B+K)的约数<=2*SQRT(B+K);这个应该知道,
再化简一下:B*B<=4(B+K),可以直接枚举B,有人担心会TLE,我们再证明一下:
化简得 :B*B-4*B+4<=4*K+4;然后K<=47777,所以可以枚举了。。
对于TYPE=0的情况, 我们可以预先求出有X个数的最小数,因为根据求约数个数的方程N=a[1]^x1+a[2]^x2.....;
num=(1+x1)*(1+x2)*。。。。;
这里我们可以DFS搜索出来。具体看看代码应该能明白
#include<cstdio>
#include<algorithm>
#include<cmath>
#include<string.h>
typedef long long ll;
using namespace std;
#define maxn 200000
const long long inf=(1ll<<62)+1;
int prime[maxn];
ll a[maxn*10];
int b[maxn*2],t; void pri()
{
for (int i=2;i*i<maxn;i++)
if (!b[i])
for (int j=i*2;j<maxn;j+=i)
b[j]=1;
for (int i=2;i<maxn;i++)
if (!b[i]) prime[++t]=i;
} int get(ll x){
int ans=1;
ll tmp=x;
for (int i=1;prime[i]<=tmp/prime[i];i++)
{
ll t=1;
while (tmp%prime[i]==0)
{
t++;
tmp/=prime[i];
}
if (t>1) ans*=t;
}
if (tmp!=1) ans*=2;
return ans;
} void dfs(int i,ll x,int n)//DFS部分
{
if (n>47777) return;
if (x<inf&&(a[n]==0||a[n]>x)) a[n]=x;//类似DP的思想
for (int j=1;j<=62;j++)
{
if (inf/prime[i]<x) break;//防止溢出,
x*=prime[i];
if (x>=inf) break;
dfs(i+1,x,n*(j+1));
}
} void solve1(int x)
{
if (a[x]!=0) printf("%I64d\n",a[x]);
else printf("INF\n");
}
void solve(ll x)
{
ll num=1;
while (num*num<=(num+x)*4)
{
if (num==get(num+x)) {printf("%I64d\n",num+x);return; }
num++;
}
printf("Illegal\n");
} int main()
{
int T;
scanf("%d",&T);
pri();
dfs(1,1,1);
for (int o=1;o<=T;o++)
{
printf("Case %d: ",o);
int type,k;
scanf("%d%d",&type,&k);
if (type) solve(k);
else solve1(k);
}
return 0;
}
HDU4542 小明系列故事——未知剩余系的更多相关文章
- hdu 4542 小明系列故事——未知剩余系
小明系列故事——未知剩余系 题意:操作0表示某数有n个约数,操作1为某数有n个非约数:n <= 47777,若是存在小于2^62的数符合,则输出该数,否则若是不存在输出Illegal,若是大于2 ...
- hdu 4542 小明系列故事——未知剩余系 反素数 + 打表
小明系列故事——未知剩余系 Time Limit: 500/200 MS (Java/Others) Memory Limit: 65535/32768 K (Java/Others) Prob ...
- hdu 4542 "小明系列故事——未知剩余系" (反素数+DFS剪枝)
传送门 参考资料: [1]:https://blog.csdn.net/acdreamers/article/details/25049767 题意: 输入两个数 type , k: ①type = ...
- HDU 4542 小明系列故事——未知剩余系 (数论|反素数)
分析 kuangbin的blog已经讲的很好了,我做一点补充 1.当做x*y>z的比较时,如果x \(\ast\) y过大,可以写成x>z/y 2.分解质因数时选择用f[][0]保存质数, ...
- HDU 4511 小明系列故事——女友的考验 (AC自动机+DP)
小明系列故事——女友的考验 Time Limit: 500/200 MS (Java/Others) Memory Limit: 65535/32768 K (Java/Others)Total ...
- HDUOJ-----4506小明系列故事——师兄帮帮忙
小明系列故事——师兄帮帮忙 Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 65535/32768 K (Java/Others)Tot ...
- HDUOJ----4501小明系列故事——买年货(三维背包)
小明系列故事——买年货 Time Limit: 5000/2000 MS (Java/Others) Memory Limit: 65535/32768 K (Java/Others)Total ...
- HDU 4511 小明系列故事——女友的考验 (AC自动机 + DP)
小明系列故事——女友的考验 Time Limit: 500/200 MS (Java/Others) Memory Limit: 65535/32768 K (Java/Others)Total ...
- HDU 4528 BFS 小明系列故事——捉迷藏
原题直通车:HDU 4528 小明系列故事——捉迷藏 分析: 标记时加两种状态就行. 代码: #include<iostream> #include<cstring> #inc ...
随机推荐
- MySQL5.7重置root密码
版本更新 缘故,好多网上的教程都不适用了,甚至连官网的文档也不是能够顺利操作的. 如果 MySQL 正在运行,首先杀之: killall -TERM mysqld. 运行mysqld_safe --s ...
- Windows Server 2003开机自动启动MySQL服务设置方法
Windows Server 2003开机自动启动MySQL服务设置方法 发布时间:2014-12-19 更新时间:2014-12-24 来源:网络 作者:eaglezhong 关键词: 2003 e ...
- 下一代NoSQL:最终一致性的末日
相比关系型数据库,NoSQL解决方案提供了shared-nothing.容错和可扩展的分布式架构等特性,同时也放弃了关系型数据库的强数据一致性和隔离性,美其名曰:"最终一致性". ...
- openSUSE13.1安装时要注意的问题(未完待续)
1.最好用官方给的imageWriter来写镜像,不要用UltraISO来写镜像,会导致安装Kaffein包错误(:)可能也会有别的错误),后来我用imageWriter写了之后就没有在安装时报错了
- Android Studio添加aar包依赖
1.将aar包考入需要依赖的模块的libs目录下 2.在需要依赖的模块的build.gradle中添加如下内容: dependencies { compile(name:'aar包名不带扩展名', e ...
- brew mac osx 上软件包管理工具
今天推荐 Mac OSX 下,方便高效的包管理工具 brew brew 的全名叫做 Homebrew 它的功能类似于 ubuntu 下同下 apt-get ,或者 Cent OS 下的 yum 等包管 ...
- Android--ViewPager的无限轮播
ViewPage_RadioButton实现带小圆点的无限轮播,效果还能凑合着用. 1.在ViewPage的监听里面这样处理 @Override public void onPageSelected( ...
- Extjs 下拉框下拉选项为Object object
使用Extjs的下拉框出现下拉选项为Object object的问题. 原因在于对store属性提供的是data信息,而不是store对象
- MongoDB学习笔记-创建、更新、删除文档
创建 MongoDB中使用insert方法来向集合插入文档,然后保存到MongoDB中. db.foo.insert({"hehe":"呵呵"} ...
- Android -- 经验分享(二)
目录 自定义两个View进行画图,让 ...