hdoj 1496 Equations (HASH)

来源:互联网 发布:windows live id账号 编辑:程序博客网 时间:2024/05/25 01:36

题目大意:方程 a*x1^2+b*x2^2+c*x3^2+d*x4^2=0 

       a,b,c,d的范围为[-50,50] ,     x1,x2,x3,x4的范围为[-100,100].

       现给出a,b,c,d,求x1,x2,x3,x4的解的个数.

 

思路:先求a*x1^2+b*x2^2 所有的值,保存于哈希表中。再查找-(c*x3^2+d*x4^2)是否保存于哈希表中。

 

问题是解决哈希表中的冲突

 

 

 线性探测再散列技术

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

  特别地,如果将数组扫描一圈仍未发现空单元,则说明哈希表已满,这会带来麻烦,但是,该情况完全可以通过扩大数组范围来避免。 

 

看了别人的代码自己重新写了一遍,46ms。学习了。

 

 

 

原创粉丝点击