public class HashTable{

private String[] name;    //关键字

private int sum;    //容量

public static void main(String[] args){    //测试

HashTable ht = new HashTable();

ht.add("chenhaitao");

ht.add("zhongcheng");

ht.add("baiyudong");

ht.add("huangshiyao");

ht.add("djflkd");

ht.add("gg");

System.out.println(ht.contains("baiyudong"));

ht.remove("huangshiyao");

System.out.println(ht.contains("huangshiyao"));

ht.print();

}

public HashTable(){             //初始化,初始容量是10个

name = new String[10];

sum = 0;

}

public int hash1(String s){                                       //哈希函数

return Math.abs(s.hashCode())%name.length;

}

public int hash2(String s){                                     //处理冲突的哈希函数

int result = Math.abs(s.hashCode())%(name.length-1);

System.out.println(s+"--"+result);

if(result%2==0){

return result + 1;

}

return result;

}

public boolean contains(String s){                  //哈希表里面是否包含字符串s

int start = hash1(s);

int i = start;

while (name[i] != null){

if(name[i].equals(s)){

return true;

}

i = (i + hash2(s))%name.length;

if(i == start){

return false;

}

}

return false;

}

public void add(String s){

if(sum>=name.length/2){

this.rehash();

}

int start = hash1(s);

int i = start;

while(name[i] != null){

if(s.equals(name[i])){

return;

}

i = (i + hash2(s))%name.length;

if(i == start){

return;

}

}

name[i] = s;

sum ++;

}

public void rehash(){                              //扩建一个哈希表为原表的两倍,把原来的哈希表添加到新表中

HashTable ht = new HashTable();

ht.name = new String[this.name.length * 2];

for(int i = 0; i < this.name.length; i ++){

if((this.name[i] != null)){

ht.add(this.name[i]);

}

}

this.name = ht.name;

this.sum = ht.sum;

}

public void remove(String s){                     //删除某个元素

if(this.contains(s)){

int i = this.getValue(s);

this.name[i] = null;

}

}

public int getValue(String s){                //得到s在哈希表中的位置

int start = this.hash1(s);

int i = start;

while(this.name[i] != null){

if(this.name[i].equals(s)){

return i;

}

i = (i + this.hash2(s))%this.name.length;

if(i == start){

return -1;

}

}

return -1;

}

public void print(){                       //输出哈希表中所有元素

for(int i = 0; i < name.length; i ++){

System.out.println(i+":"+name[i]);

}

}

public int size(){          //哈希表存储元素的个数

return this.sum;

}

public int length(){            //哈希表的长度

return this.name.length;

}

}

java HastTable实现的更多相关文章

  1. Spark案例分析

    一.需求:计算网页访问量前三名 import org.apache.spark.rdd.RDD import org.apache.spark.{SparkConf, SparkContext} /* ...

  2. HashSet HashTable HashMap的区别 及其Java集合介绍

    (1)HashSet是set的一个实现类,hashMap是Map的一个实现类,同时hashMap是hashTable的替代品(为什么后面会讲到). (2)HashSet以对象作为元素,而HashMap ...

  3. JAVA的HashTable源码分析

    Hashtable简介 Hashtable同样是基于哈希表实现的,同样每个元素是一个key-value对,其内部也是通过单链表解决冲突问题,容量不足(超过了阀值)时,同样会自动增长.Hashtable ...

  4. Java /C# 实现文件压缩

    纯粹为了记录. 参考了 https://www.cnblogs.com/zeng1994/p/7862288.html import java.util.List; import java.util. ...

  5. Java面试(二)

    1 同步方法 VS 同步代码块: java中,每一个对象都有一把锁,线程用synchronized获取对象上的锁. 非静态同步方法:锁是类的对象的锁. 静态同步方法:锁的是类本身. 同步方法块:锁是可 ...

  6. java中hashmap和hashtable和hashset的区别

    hastTable和hashMap的区别:(1)Hashtable是基于陈旧的Dictionary类的,HashMap是Java 1.2引进的Map接口的一个实现.(2)这个不同即是最重要的一点:Ha ...

  7. 由Java 15废弃偏向锁,谈谈Java Synchronized 的锁机制

    Java 15 废弃偏向锁 JDK 15已经在2020年9月15日发布,详情见 JDK 15 官方计划.其中有一项更新是废弃偏向锁,官方的详细说明在:JEP 374: Disable and Depr ...

  8. 故障重现(内存篇2),JAVA内存不足导致频繁回收和swap引起的性能问题

    背景起因: 记起以前的另一次也是关于内存的调优分享下   有个系统平时运行非常稳定运行(没经历过大并发考验),然而在一次活动后,人数并发一上来后,系统开始卡. 我按经验开始调优,在每个关键步骤的加入如 ...

  9. Elasticsearch之java的基本操作一

    摘要   接触ElasticSearch已经有一段了.在这期间,遇到很多问题,但在最后自己的不断探索下解决了这些问题.看到网上或多或少的都有一些介绍ElasticSearch相关知识的文档,但个人觉得 ...

随机推荐

  1. Linux平台的boost安装全解

    @import url(http://i.cnblogs.com/Load.ashx?type=style&file=SyntaxHighlighter.css); @import url(/ ...

  2. CentOS7安装使用MySQL

    安装MySQL 添加mysql源 # rpm -Uvh http://repo.mysql.com//mysql57-community-release-el7-7.noarch.rpm 安装mysq ...

  3. 使用gradle构建java项目

    gradle是什么东东 gradle是继ant,maven之后另外一种的面向java的自动化项目构建工具,他是基于groovy语言的.相对于ant,maven,gradle显得更加简单. 安装grad ...

  4. Spring声明式事务(xml配置事务方式)

    Spring声明式事务(xml配置事务方式) >>>>>>>>>>>>>>>>>>>& ...

  5. AngularJS Filter用法详解【转+实际测试】 格式化货币

    AngularJS内建了一些常用的Filter,我们一一来看一下. currencyFilter(currency): 用途:格式化货币 方法原型: function(amount, currency ...

  6. sql - 选出指定范围的行

    Select no=Identity(int,1,1),* Into #temptable From dbo.tName order by fName --利用Identity函数生成记录序号 Sel ...

  7. 完全步卸载oracle11g步骤

    完全 步 卸载oracle11g骤: . 开始->设置->控制面板->管理工具->服务 停止所有Oracle服务.  . 开始->程序->Oracle - OraH ...

  8. javascript 用函数实现“继承”

    一.知识储备: 1.枚举属性名称的函数: (1)for...in:可以在循环体中遍历对象中所有可枚举的属性(包括自有属性和继承属性) (2)Object.keys():返回数组(可枚举的自有属性) ( ...

  9. JavaWeb学习----JSP简介及入门(JSP结构及JSP处理)

    ​[声明] 欢迎转载,但请保留文章原始出处→_→ 艾水及水:http://www.cnblogs.com/liuhepeng 文章来源:http://www.cnblogs.com/liuhepeng ...

  10. 神经网络中的XOR问题

    XOR问题 解决办法: 网络如图 其中激活函数 ReLU,令 即可解决XOR问题.