POJ 1840 HASH
题目链接:http://poj.org/problem?id=1840
题意:公式a1x1^3+ a2x2^3+ a3x3^3+ a4x4^3+ a5x5^3=0,现在给定a1~a5,求有多少个(x1~x5)的组合使得公式成立。并且(x1~x5)取值再[-50,50]且不能为0
思路:因为x的值范围比较小,只有100.所以可以先求出 a1x1^3+a2x2^3+a3x3^3. 然后在求 (-1)*(a4x4^3+a5x5^3)从前面的所得的Hash表进行二分查找。
#include<iostream>
#include<algorithm>
#include<cstring>
#include<string>
#include<cstdio>
#include<vector>
#include<cmath>
#include<time.h>
#include<map>
using namespace std;
typedef long long int LL;
const int MAXN=+;//100^3
int a,b,c,d,e;
int Hash[MAXN];
int main(){
#ifdef kirito
freopen("in.txt","r",stdin);
freopen("out.txt","w",stdout);
#endif
int start=clock();
while(~scanf("%d%d%d%d%d",&a,&b,&c,&d,&e)){
int cnt=,ans=;
for(int i=-;i<=;i++){ //make a1x1^3+a2x2^3+a3x3^3
if(i==){continue;}
for(int j=-;j<=;j++){
if(j==){continue;}
for(int k=-;k<=;k++){
if(k==){continue;}
int Sum=a*i*i*i+b*j*j*j+c*k*k*k;
Hash[cnt++]=Sum;
}
}
}
sort(Hash,Hash+cnt); //sorted
for(int i=-;i<=;i++){ //make (-1)*(a4x4^3+a5x5^3)
if(i==){continue;};
for(int j=-;j<=;j++){
if(j==){continue;}
int Sum=(-)*(d*i*i*i+e*j*j*j);//the search number
for(int k=lower_bound(Hash,Hash+cnt,Sum)-Hash;k<cnt;k++){//binary search the number
if(Hash[k]!=Sum){
break;
}
else{
ans++;
}
}
}
}
printf("%d\n",ans);
}
#ifdef LOCAL_TIME
cout << "[Finished in " << clock() - start << " ms]" << endl;
#endif
return ;
}
POJ 1840 HASH的更多相关文章
- Eqs - poj 1840(hash)
		题意:对于方程:a1x13+ a2x23+ a3x33+ a4x43+ a5x53=0 ,有xi∈[-50,50], xi != 0, any i∈{1,2,3,4,5}. 现在给出a1,a2,a3, ... 
- poj  1840 Eqs  (hash)
		题目:http://poj.org/problem?id=1840 题解:http://blog.csdn.net/lyy289065406/article/details/6647387 小优姐讲的 ... 
- POJ 1840 Eqs 二分+map/hash
		Description Consider equations having the following form: a1x13+ a2x23+ a3x33+ a4x43+ a5x53=0 The co ... 
- POJ 1840 Eqs(hash)
		题意 输入a1,a2,a3,a4,a5 求有多少种不同的x1,x2,x3,x4,x5序列使得等式成立 a,x取值在-50到50之间 直接暴力的话肯定会超时的 100的五次方 10e了都 ... 
- POJ 3274 HASH
		题目链接:http://poj.org/problem?id=3274 题意+思路: 点击这里 补充:因为有减法运算,所以可能会造成运算后结果为负数,所以需要把结果统一转换成正数[不然数组下标访问不到 ... 
- POJ 3349 HASH
		题目链接:http://poj.org/problem?id=3349 题意:你可能听说话世界上没有两片相同的雪花,我们定义一个雪花有6个瓣,如果存在有2个雪花相同[雪花是环形的,所以相同可以是旋转过 ... 
- POJ 2785 HASH
		题目链接:http://poj.org/problem?id=2785 题意:给定n行数字,每行4个数分别是a,b,c,d,现在要求能有多少个(a,b,c,d)组合并且和为0 思路:n^2统计所有(a ... 
- POJ 1840 Eqs 解方程式, 水题 难度:0
		题目 http://poj.org/problem?id=1840 题意 给 与数组a[5],其中-50<=a[i]<=50,0<=i<5,求有多少组不同的x[5],使得a[0 ... 
- POJ 1840 Eqs
		Eqs Time Limit: 5000MS Memory Limit: 65536K Total Submissions: 15010 Accepted: 7366 Description ... 
随机推荐
- Mac shell 添加VPN 路由
			苦于每次使用内网VPN,都需要手动添加route来设置网络的映射,才可以正常使用VPN. 每次都需要自动添加,当然就是觉得很烦,想到Mac的shell.反正每次添加的时候都是在终端执行添加路由.为了方 ... 
- codeforces   501C. Misha and Forest   解题报告
			题目链接:http://codeforces.com/problemset/problem/501/C 题目意思:有 n 个点,编号为 0 - n-1.给出 n 个点的度数(即有多少个点跟它有边相连) ... 
- java转换json需要导入的jar包,org/apache/commons/lang/exception/NestableRuntimeException
			缺少相应jar包都会有异常,根据异常找jar包导入...... 这里我说下lang包,因为这个包我找了好半天: 我用的是: commons-lang3-3.1.jar 出现异常: jav ... 
- Android Multimedia框架总结(二)MediaPlayer框架及播放网络视频案例
			前言:前面一篇我们介绍MediaPlayer相关方法,有人说,没有实际例子,看得不是很明白,今天在分析MediaPlayer时,顺带一个播放网络视频例子.可以自行试试.今天分析的都是下几篇介绍各个模块 ... 
- 【leetcode】Insert Interval(hard)★
			Given a set of non-overlapping intervals, insert a new interval into the intervals (merge if necessa ... 
- ajax,下拉框级联
			js代码: $(document).ready(function() { $("#type1").change(function(){ var type1Code=$(" ... 
- centos 6.5 配置LDAP服务器+客户端!
			各种度娘!各种歌哥!网上教程参差不齐,历时1天,终于完成,不敢独享,遂,总结分享之,有问题可以留言,知无不言...开始吧 Note: 本次配置的服务器环境是<redhat enterprise ... 
- Xcode找不到模拟器
			今天新建的工程,突然发现模拟器找不到了,之前遇到过忘记怎么解决了,于是再次记录下解决方法. 首先说下问什么找不到模拟器了,原因就是之前运行的版本和现在xcode的版本不同(的确,我从 Xcode7.3 ... 
- 多线程编程1 - NSThread
			每个iOS应用程序都有个专门用来更新显示UI界面.处理用户的触摸事件的主线程,因此不能将其他太耗时的操作放在主线程中执行,不然会造成主线程堵塞(出现卡机现象),带来极坏的用户体验.一般的解决方案就是将 ... 
- 有关Oracle数据库
			创建数据库(DCA):http://jingyan.baidu.com/article/cbcede07cf42ef02f40b4dc2.html 创建表(连接数据库,sql创建数据表):http:/ ... 
