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. 29、Jquery Ajax

    Ajax Asynchronsous Javascript and XML(异步Javascript和XML). Ajax 是一种无需重新加载整个页面的情况下,更新局部页面的技术. 不是指一种单一的技 ...

  2. U3D 摄像机镜头控制

    如果要实现,摄像机跟随着主角运动,还有运用滚轮实现镜头的方法和缩小的实现原理 方法1:把主摄像机放到主角的下面,作为一个子对象,调整好摄像机的视角,此时就会跟随了. 方法2:用代码让摄像机的相关的po ...

  3. css 导航条 布局

    导航条(简单易用的导航) <!DOCTYPE html> <html> <head> <style> ul { list-style-type:none ...

  4. ASP.NET MVC 自我总结的便捷开发实例

    前言 工作了这么久了,接触ASP.NET MVC已经很久了,一直都想总结一下它的一些实用的,经常使用的一些技巧,但是因为一直都很懒,也不想总结,所以一直都没有好好写出来,趁着现在有这种冲劲,那么就先把 ...

  5. [上传下载] C# UpLoadFiles文件上传类 (转载)

    点击下载 UpLoadFiles.zip 主要功能如下 /// <summary> /// 上传文件 /// </summary> /// <param name=&qu ...

  6. ie6常见的兼容性

    1.IE6怪异解析之padding与border算入宽高 原因:未加文档声明造成非盒模型解析 解决方法:加入文档声明<!doctype html> 2.IE6在块元素.左右浮动.设定mar ...

  7. ACM HDU 1021 Fibonacci Again

    #include<iostream> using namespace std; int main() { int n; while(cin>>n) { if((n+1)%4== ...

  8. Binary Tree Level Order Traversal II 解题思路

    思路: 与Binary Tree Level Order Traversal I 几乎一样.只是最后将结果存放在栈里,然后在栈里再传给向量即可. 再次总结思路: 两个queue,先把第一个放进q1,循 ...

  9. LINUX 添加定时任务

    LINUX 添加定时任务 crontab - l按 i:x 先按 esc然后 敲入 命令 :x*/5 3 * * 0 /root/ v.sh ..重启服务 service crond restart

  10. centos git gitolite安装笔记

    export PATH=/home/git/bin:$PATH echo PATHgit branch 查看本地分支 git branch -a 查看远程分支 git fetch 获取远程分支 git ...