HDU-1496(哈希表)
Hash入门第一题
题意:
问题描述
考虑具有以下形式的方程:
a * x1 ^ 2 + b * x2 ^ 2 + c * x3 ^ 2 + d * x4 ^ 2 = 0
a,b,c,d是来自区间[-50,50]的整数和它们中的任何不能为0。
这是考虑的溶液的系统(X1,X2,X3,X4),其验证方程,xi是从[-100,100]和XI的整数!= 0,任意i∈{1, 2,3,4}。
确定满足给定方程的解决方案数量。
输入
输入包含几个测试用例。每个测试用例由包含4个系数a,b,c,d的单行组成,由一个或多个空格分隔。
文件结束。
产量
对于每个测试用例,输出包含解决方案数量的单行。
样本输入
1 2 3 -4
1 1 1 1
样本输出
39088
0
题目分析:
最开始的想法会是从0-100里面找x1,x2,x3,x4, 4个任意不同组合,会用4重循环,然后用得到的值×16
如果用Hash的思路的话
1.用内存换时间
2.只需要两重循环,+Hash存储查找就行了。
3.将4重循环分解为两个两重循环
4.查找满足条件的记录下来
#include <stdio.h>
#include <memory.h>
int pin[101];//用来记录x(i)^2的值
int hash[2000003];//hash表的key值
int main(){
int a, b, c, d;
int sum;
//pin 用来存储每个x(i)的可能值
for( int i = 1; i <= 100; i++ )
pin[i] = i * i;
while(scanf("%d%d%d%d",&a,&b,&c,&d)!=EOF){
if((a>0 && b>0 && c>0 && d>0)||(a<0 && b<0 && c<0 && d<0)){
printf("0\n");
continue;
}
memset(hash,0,sizeof(hash));
for(int i = 1; i<=100;i++){
for(int j=1;j<=100;j++){
//构造哈希函数让每个值都有一个不同的key
hash[a*pin[i]+b*pin[j]+1000000]++;
}
}
sum = 0;
for(int i= 1;i<=100;i++){
for(int j=1;j<=100;j++){
//查找是否有满足条件的key,有的话记录+1
sum += hash[-(c*pin[i]+d*pin[j])+1000000];
}
}
printf("%d\n",sum*16);
}
return 0;
}
当然可以来一个它的优化版本了
因为两层循环最多只可能产生10000个不同的结果,开200w的数组将会浪费很多初始化的时间,所以开小数组+处理冲突会比较好
//由于100 * 100 只有10000个不同的结果,
//因此只需要大于10000就可以了
//因此本题是可以根据这个条件对上面那个代码进行优化的
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define MAX 50001
int f[MAX],g[MAX];
int hash(int k){
int t = k%MAX;
if( t < 0 )
t += MAX;
//这个是解决冲突的核心,
//前面的f[t]用来将占位的位置后移 后面那个g[t]的存在当然是为了查找
while(f[t]!=0 && g[t]!=k){
t = (t+1)%MAX;
}
return t;
}
int main(){
int a, b, c, d, i, j,s,p, sum=0, t[101];
for( i=1;i<=100;i++)
t[i] = i*i;
while(~scanf("%d%d%d%d",&a,&b,&c,&d)){
if((a>0 && b>0 && c>0 && d>0)||(a<0 && b<0 && c<0 && d<0)){
printf("0\n");
continue;
}
memset(f,0,sizeof(f));
for( i=1;i<=100;i++){
for( j=1;j<=100;j++){
s = a*t[i] + b*t[j];
p = hash(s);
g[p] = s;
f[p]++;
}
}
sum = 0; //用来计数的
for( i=1;i<=100;i++){
for( j=1;j<=100;j++){
s = -(c*t[i]+d*t[j]);
p = hash(s);
//如果p这个数在f数组中存在则计数加1
sum += f[p];
}
}
printf("%d\n",sum*16);
}
}
HDU-1496(哈希表)的更多相关文章
- hdu 1496 Equations hash表
hdu 1496 Equations hash表 题目链接 http://acm.hdu.edu.cn/showproblem.php?pid=1496 思路: hash表,将原来\(n^{4}\)降 ...
- hdu acm 1425 sort(哈希表思想)
sort Time Limit: 6000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submis ...
- hdu 5183. Negative and Positive (哈希表)
Negative and Positive (NP) Time Limit: 3000/1500 MS (Java/Others) Memory Limit: 65536/65536 K (Ja ...
- HDU4887_Endless Punishment_BSGS+矩阵快速幂+哈希表
2014多校第一题,当时几百个人交没人过,我也暴力交了几发,果然不行. 比完了去学习了BSGS才懂! 题目:http://acm.hdu.edu.cn/showproblem.php?pid=4887 ...
- [PHP内核探索]PHP中的哈希表
在PHP内核中,其中一个很重要的数据结构就是HashTable.我们常用的数组,在内核中就是用HashTable来实现.那么,PHP的HashTable是怎么实现的呢?最近在看HashTable的数据 ...
- Java 哈希表运用-LeetCode 1 Two Sum
Given an array of integers, find two numbers such that they add up to a specific target number. The ...
- ELF Format 笔记(十五)—— 符号哈希表
ilocker:关注 Android 安全(新手) QQ: 2597294287 符号哈希表用于支援符号表的访问,能够提高符号搜索速度. 下表用于解释该哈希表的组织,但该格式并不属于 ELF 规范. ...
- Java基础知识笔记(一:修饰词、向量、哈希表)
一.Java语言的特点(养成经常查看Java在线帮助文档的习惯) (1)简单性:Java语言是在C和C++计算机语言的基础上进行简化和改进的一种新型计算机语言.它去掉了C和C++最难正确应用的指针和最 ...
- 什么叫哈希表(Hash Table)
散列表(也叫哈希表),是根据关键码值直接进行访问的数据结构,也就是说,它通过把关键码值映射到表中一个位置来访问记录,以加快查找的速度.这个映射函数叫做散列函数,存放记录的数组叫做散列表. - 数据结构 ...
- 【哈希表】CodeVs1230元素查找
一.写在前面 哈希表(Hash Table),又称散列表,是一种可以快速处理插入和查询操作的数据结构.哈希表体现着函数映射的思想,它将数据与其存储位置通过某种函数联系起来,其在查询时的高效性也体现在这 ...
随机推荐
- Jmeter--随机生成浮点数
post接口中需要随机生成目标对象的地理位置: 所以就使用了javaScript函数,如下所示: { "Location": { "Altitude": ${_ ...
- POJ 1644 分苹果 (递归解法)
把M个同样的苹果放在N个同样的盘子里,允许有的盘子空着不放,问共有多少种不同的分法?(用K表示)5,1,1和1,5,1 是同一种分法. Input 第一行是测试数据的数目t(0 <= t < ...
- Using Lookup Tables to Accelerate Color Transformations
转自:http://http.developer.nvidia.com/GPUGems2/gpugems2_chapter24.html In feature-film visual-effects ...
- ASP.Net Mvc 5 学习记录2015-9-9
我之前一直都是学习和开发都采用ASP.Net WebForm,对MVC的一直都是一知半解,最初以为ASP.Net WebForm的N层架构就是MVC.其实N层架构设计思想是"高内聚,低耦合& ...
- 【js】数组添加与删除
做个表格,就会容易记忆四种方法. 返回值 是否改变数组长度 位置 功能 push() 改变数组的长度 是 末位 添加 unshift() 改变数组的长度 是 首位 添加 pop( ...
- 浅谈React和VDom关系
组件化 组件的封装 组件的复用 组件的封装 视图 数据 视图和数据之间的变化逻辑 import React, {Component} from 'react'; export default clas ...
- Qt5连接Mysql环境配置
已安装的环境:Mysql5.7 64bit ,Qt5.12 64bit. 到mysql官方下载mysql5.7 64bit的压缩包,解压,复制下图框内四个文件. 将四个文件复制到Qt安装目录下bin目 ...
- Linux系统结构 详解(转)
Linux系统一般有4个主要部分: 内核.shell.文件系统和应用程序.内核.shell和文件系统一起形成了基本的操作系统结构,它们使得用户可以运行程序.管理文件并使用系统.部分层次结构如图1-1所 ...
- IO流,Properties基本功能和遍历
import java.util.Enumeration; import java.util.Iterator; import java.util.Properties; import java.ut ...
- SASS实现代码的重用:混合器Mixin、继承
1. 继承: @extend sass允许一个选择器,继承另一个选择器,通过@extend实现 .class1{ border: 1px solid #333; } .class2{ @extend ...