HDU 4937 Lucky Number(2014 Multi-University Training Contest 7)
思路:先枚举 a*bas +b = n 求出 bas 在sqrt(n)到n的 (bas>a&&bas>b)
再枚举 a*bas*bas+b*bas+c =n 求出bas 在 n^(1/3) 到sqrt(n)的 (bas >a&&bas>b&&bas>c)
上面 a b c 均只有 3 4 5 6 四种取值。
剩下的 直接 n^(1/3) 枚举 效率为 n的三分之一 次方。
//============================================================================
// Name : 1003.cpp
// Author :
// Version :
// Copyright : Your copyright notice
// Description : Hello World in C++, Ansi-style
//============================================================================ #include <iostream>
#include<cstring>
#include<algorithm>
#include<cmath>
#include<vector>
#include<cstdio>
#define LL long long
#define MAXN 1000050
using namespace std;
LL ans[MAXN];
int f[]={,,,};
int main() {
int tt,ri=;
LL n;
scanf("%d",&tt);
while(tt--)
{
int tail=;
scanf("%I64d",&n);
if(n>=&&n<=)
{ printf("Case #%d: -1\n",++ri);
continue;
}
if(n<)
{ printf("Case #%d: %d\n",++ri,tail);
continue;
}
for(LL i=;i<;++i)
{
for(LL j=;j<;++j)
{
if((n-f[j])%f[i]==&&(n-f[j])/f[i]>f[i]&&(n-f[j])/f[i]>f[j])
ans[tail++]=(n-f[j])/f[i];
}
}
for(LL i=;i<;++i)
{
for(LL j=;j<;++j)
{
for(LL k=;k<;++k)
{
LL l,r;
l=,r=;
LL ii=f[i];
LL jj=f[j];
LL kk=f[k];
while(r-l>)
{
LL x=(l+r)>>;
LL cal=ii*x*x+jj*x+kk;
if(cal>=n)r=x;
else l=x;
}
if(ii*l*l+jj*l+kk==n&&l>f[i]&&l>f[j]&&l>f[k])
ans[tail++]=l;
if(ii*r*r+jj*r+kk==n&&r>f[i]&&r>f[j]&&r>f[k])
ans[tail++]=r;
}
}
} for(LL i=;i*i*i<=n;++i)
{
LL x=n;
int flag=;
while(x)
{
LL tmp=x%i;
if(tmp<||tmp>)
flag=;
x/=i;
}
if(flag)
ans[tail++]=i;
}
sort(ans,ans+tail);
tail=unique(ans,ans+tail)-ans; printf("Case #%d: %d\n",++ri,tail);
}
return ;
}
HDU 4937 Lucky Number(2014 Multi-University Training Contest 7)的更多相关文章
- 枚举 + 进制转换 --- hdu 4937 Lucky Number
Lucky Number Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Others)To ...
- 2014多校第七场1003 || HDU 4937 Lucky Number
题目链接 题意 : 给定一个十进制n,让你转化成某个进制的数,让这个数只包含3 4 5 6这些数字,这个进制就成为n的幸运数字,输出有多少幸运数字,例如19,5进制表示是34,所以5是19的一个幸运数 ...
- HDU 4937 Lucky Number (数学,进制转换)
题目 参考自博客:http://blog.csdn.net/a601025382s/article/details/38517783 //string &replace(iterator fi ...
- hdu 4937 Lucky Number
虽然算法清晰的不能再清晰,但是实现总是边角料错这错那. 题目大意: 给出n,找出一些进制,使得n在该进制下仅为3,4,5,6表示 解题思路: 首先,4-10000进制直接枚举计算出每一位 此外,最多只 ...
- HDU 4937 Lucky Number 规律题_(:зゝ∠)_
把全部合法的进制打出来会发现合法的进制都是在 n/3 n/4 n/5的边上 然后暴力边上的进制数.. #include <cstdio> #include <set> type ...
- HDU 4937 Lucky Number 搜索
题意: 给你一个数,求在多少种不同的进制下这个数每一位都是3.4.5.6中的一个. 思路: 搜索.枚举这个数在任意进制下的表示,判断是否合法.当数字只有3.4.5.6时,必定有无穷种. 因为数字太大, ...
- HDOJ 4937 Lucky Number
当进制转换后所剩下的为数较少时(2位.3位),相应的base都比較大.能够用数学的方法计算出来. 预处理掉转换后位数为3位后,base就小于n的3次方了,能够暴力计算. . .. Lucky Numb ...
- HDU 3346 Lucky Number
水题 #include<cstdio> #include<cstring> #include<cmath> #include<algorithm> us ...
- hdu 6301 Distinct Values (2018 Multi-University Training Contest 1 1004)
Distinct Values Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)T ...
随机推荐
- flume的使用
1.flume的安装和配置 1.1 配置java_home,修改/opt/cdh/flume-1.5.0-cdh5.3.6/conf/flume-env.sh文件
- Python之路,Day1 - Python基础1
本节内容 Python介绍 发展史 Python 2 or 3? 安装 Hello World程序 变量 用户输入 模块初识 .pyc是个什么鬼? 数据类型初识 数据运算 表达式if ...else语 ...
- iOS全军覆没!分分钟教你徒手破解iPhone
http://iphone.tgbus.com/news/class/201503/20150304141407.shtml 破解id密码的最新dns 218.59.181.182
- C#知识点总结系列:5、CLR的组成和运转
clr基本 CLR(Common Language Runtime)是一个可由多种编程语言使用的“运行时”.(例如:c#,c++/cli,vb,f#,ironpython,ironruby,il... ...
- 关于json-p
关于json-p 目录 关于json-p json-p是什么 json-p原理分析 json-p的缺点 json-p是什么 json-p实际上是一种跨域ajax发送http请求的方法,它不是什么全新的 ...
- DataTable转换为Json字符串的三种方法
//第一种:使用StringBuilder public string DataTableToJson(DataTable table) { var JsonString = new StringB ...
- IntrospectorCleanupListener作用
<!--web.xml--><listener> <listener-class>org.springframework.web.util.Introspector ...
- 当shiro做成动态URL管理时出现循环注入BeanCurrentlyInCreationException的问题解决方法
<!-- Shiro的Web过滤器 --> <bean id="shiroFilter" class="org.apache.shiro.spring. ...
- away3D改造白皮书
[多余的stage3D的考虑] 因为away3D为了支持stage本身可以有n个stage3D对象这个特性,在诸如MaterialPassBase.SubGeometry中,为Program3D.Ve ...
- Windows下 Maven 使用 阿里云镜像配置
新建或者修改文件: C:\Users\user\.m2\settings.xml <settings xmlns="http://maven.apache.org/SETTINGS/1 ...