整数Hash散列总结

2024-09-09 08:32
文章标签 总结 整数 hash 散列

本文主要是介绍整数Hash散列总结,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

方法:  

 step1  :线性探测

 step2 散列

  当 h(k)位置已经存储有元素的时候,依次探查(h(k)+i) mod S, i=1,2,3…,直到找到空的存储单元为止。其中,S为 数组长度

HDU 1496   a*x1^2+b*x2^2+c*x3^2+d*x4^2=0 。 x在 [-100,100] 解的个数 

const   int  MaxN = 30000 ;
bool    used[MaxN] ;struct  Hash{int  val  ;int  count ;
} ;
Hash HashTable[MaxN] ;int   searchHash(int  n){int x = n  ;while(x < 0)  x += MaxN ;while(x >= MaxN) x -= MaxN ;while(used[x] && HashTable[x].val != n){x++ ;if(x >=MaxN) x -= MaxN ;}return x ;
}void  insertTable(int n){int  id = searchHash(n) ;HashTable[id].val = n ;used[id] = 1  ;HashTable[id].count++ ;
}int   main(){int a , b , c , d , i ,  j  , ans , id ;while(scanf("%d%d%d%d" ,&a , &b ,&c ,&d) != EOF){if(a > 0 && b > 0 && c > 0 && d > 0){puts("0")  ; continue ;}if(a < 0 && b < 0 && c < 0 && d < 0){puts("0")  ; continue ;}memset(used , 0 , sizeof(used)) ;memset(HashTable , 0 , sizeof(HashTable)) ;ans = 0 ;for(i = 1 ; i <= 100 ; i++)for(j = 1 ; j <= 100 ; j++)insertTable(a*i*i + b*j*j) ;for(i = 1 ; i <= 100 ; i++){for(j = 1 ; j <= 100 ; j++){id = searchHash(- c*i*i - d*j*j) ;ans += HashTable[id].count ;}}printf("%d\n" , ans*16) ;}return 0 ;
}


POJ 1186   k1*x1^p1 + k2*x2^p2 + ...+kn*xn^pn = 0  , n <=6 ,  1 <=x <= 150 方程的个数

const int MaxN = 4000000 ;
bool  used[MaxN] ;struct Hash{int  val ;int  count ;
};
Hash HashTable[MaxN] ;int  searchHash(int n){int  x = n ;while(x < 0) x += MaxN ;while(x >= MaxN) x -= MaxN ;while(used[x] && HashTable[x].val != n){if(++x >= MaxN) x -= MaxN ;}HashTable[x].val = n ;return x ;
}void insertTable(int n){int id = searchHash(n) ;HashTable[id].count++ ;used[id] = 1 ;
}int   Pow(int x , int y){int ans = 1 ;for(; y ; y >>= 1 , x *= x){if(y&1)  ans *= x ;}return ans  ;
}int   N , M  , k[7] , p[7]  , mid , ans  ;void  GaoLeft(int id , int sum){if(id == mid){insertTable(sum) ;return ;}for(int i = 1 ; i <= M ; i++)GaoLeft(id+1 , sum + k[id] * Pow(i , p[id])) ;
}void  GaoRight(int id , int sum){if(id == N){int s = -sum ;ans += HashTable[searchHash(s)].count ;return  ;}for(int i = 1 ; i <= M ; i++)GaoRight(id+1 , sum + k[id] * Pow(i , p[id])) ;
}int  main(){int i ;scanf("%d%d" ,&N , &M) ;memset(HashTable , 0 , sizeof(HashTable)) ;for(i = 0 ; i < N ; i++) scanf("%d%d" ,&k[i] , &p[i]) ;mid = N>>1 ;ans = 0 ;GaoLeft(0 , 0) ;GaoRight(mid , 0) ;printf("%d\n" , ans) ;return 0 ;
}

zoj2672  N数,求其子数列为等差数列,且最长并输出。


struct Hash{static const int mask = 0x7fff ;int p[32768] , q[32768] ;  //做p->q的映射map<p , q>void  clear(){memset(q , -1 , sizeof(q)) ;}int & operator[] (int k){  //注意这个引用int i = k & mask ;while(q[i] != -1 && p[i] != k)  i = (i+1) & mask ;p[i] = k ;return q[i] ;}
};int  n , x[3003] ;
short dp[3003][3003] ;void  dfs(int k , int a , int b){if(k == 2){printf("%d %d" , a , b) ;return  ;}dfs(k-1 , b-a , a) ;printf(" %d" , b) ;
}int  main(){int i , j , ans  , L , R  , k  ;while(scanf("%d" ,&n) != EOF){for(i = 1 ; i <= n ; i++)  scanf("%d" ,&x[i]) ;Hash h ;h.clear() ;for(i = 1 ; i <= n ; i++)for(j = i+1 ; j <= n ; j++)dp[i][j] = 2 ;ans = 1  ;for(i = 1 ; i <= n ; i++){for(j = i+1 ; j <= n ; j++){k = h[ x[j] - x[i] ] ;if(k != -1)dp[i][j] = dp[k][i] + 1 ;if(ans < dp[i][j]){ans = dp[i][j] ;L = i ;R = j ;}}h[ x[i] ] = i ;}printf("%d\n" , ans)  ;if(ans == 1)  printf("%d\n" , x[1]) ;else{dfs(ans , x[L] , x[R]) ;puts("") ;}}return 0 ;
}

 






这篇关于整数Hash散列总结的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1150651

相关文章

SQL中JOIN操作的条件使用总结与实践

《SQL中JOIN操作的条件使用总结与实践》在SQL查询中,JOIN操作是多表关联的核心工具,本文将从原理,场景和最佳实践三个方面总结JOIN条件的使用规则,希望可以帮助开发者精准控制查询逻辑... 目录一、ON与WHERE的本质区别二、场景化条件使用规则三、最佳实践建议1.优先使用ON条件2.WHERE用

Nginx Location映射规则总结归纳与最佳实践

《NginxLocation映射规则总结归纳与最佳实践》Nginx的location指令是配置请求路由的核心机制,其匹配规则直接影响请求的处理流程,下面给大家介绍NginxLocation映射规则... 目录一、Location匹配规则与优先级1. 匹配模式2. 优先级顺序3. 匹配示例二、Proxy_pa

Android学习总结之Java和kotlin区别超详细分析

《Android学习总结之Java和kotlin区别超详细分析》Java和Kotlin都是用于Android开发的编程语言,它们各自具有独特的特点和优势,:本文主要介绍Android学习总结之Ja... 目录一、空安全机制真题 1:Kotlin 如何解决 Java 的 NullPointerExceptio

MySQL基本查询示例总结

《MySQL基本查询示例总结》:本文主要介绍MySQL基本查询示例总结,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录Create插入替换Retrieve(读取)select(确定列)where条件(确定行)null查询order by语句li

Linux区分SSD和机械硬盘的方法总结

《Linux区分SSD和机械硬盘的方法总结》在Linux系统管理中,了解存储设备的类型和特性是至关重要的,不同的存储介质(如固态硬盘SSD和机械硬盘HDD)在性能、可靠性和适用场景上有着显著差异,本文... 目录一、lsblk 命令简介基本用法二、识别磁盘类型的关键参数:ROTA查询 ROTA 参数ROTA

Qt实现网络数据解析的方法总结

《Qt实现网络数据解析的方法总结》在Qt中解析网络数据通常涉及接收原始字节流,并将其转换为有意义的应用层数据,这篇文章为大家介绍了详细步骤和示例,感兴趣的小伙伴可以了解下... 目录1. 网络数据接收2. 缓冲区管理(处理粘包/拆包)3. 常见数据格式解析3.1 jsON解析3.2 XML解析3.3 自定义

Python实现图片分割的多种方法总结

《Python实现图片分割的多种方法总结》图片分割是图像处理中的一个重要任务,它的目标是将图像划分为多个区域或者对象,本文为大家整理了一些常用的分割方法,大家可以根据需求自行选择... 目录1. 基于传统图像处理的分割方法(1) 使用固定阈值分割图片(2) 自适应阈值分割(3) 使用图像边缘检测分割(4)

Windows Docker端口占用错误及解决方案总结

《WindowsDocker端口占用错误及解决方案总结》在Windows环境下使用Docker容器时,端口占用错误是开发和运维中常见且棘手的问题,本文将深入剖析该问题的成因,介绍如何通过查看端口分配... 目录引言Windows docker 端口占用错误及解决方案汇总端口冲突形成原因解析诊断当前端口情况解

java常见报错及解决方案总结

《java常见报错及解决方案总结》:本文主要介绍Java编程中常见错误类型及示例,包括语法错误、空指针异常、数组下标越界、类型转换异常、文件未找到异常、除以零异常、非法线程操作异常、方法未定义异常... 目录1. 语法错误 (Syntax Errors)示例 1:解决方案:2. 空指针异常 (NullPoi

使用C语言实现交换整数的奇数位和偶数位

《使用C语言实现交换整数的奇数位和偶数位》在C语言中,要交换一个整数的二进制位中的奇数位和偶数位,重点需要理解位操作,当我们谈论二进制位的奇数位和偶数位时,我们是指从右到左数的位置,本文给大家介绍了使... 目录一、问题描述二、解决思路三、函数实现四、宏实现五、总结一、问题描述使用C语言代码实现:将一个整