package com.wpr.collection;

import java.util.LinkedList;
import java.util.List; public class HashTable<AnyType> { private static final int DEFAULT_TABLE_SIZE = 101; private List<AnyType>[] theList;
private int curSize; public HashTable() {
this(DEFAULT_TABLE_SIZE);
} public HashTable(int size) {
//构造一个质数长度的链表
this.theList = new LinkedList[nextPrime(size)];
for(int i=0;i<theList.length;i++){
theList[i]= new LinkedList<>();
}
}
/**
* 插入,如果元素已经存在,直接返回
* @param x
*/
public void insert(AnyType x){
List<AnyType> temp = theList[myHast(x)];
if(!temp.contains(x)){
temp.add(x);
if(++curSize>theList.length)
reHash();
}
}
/**
* 表的size太小,数据的长度和表长相等时重新调整表长,装填因子为1
*/
private void reHash() {
List<AnyType>[] old = theList;
theList = new LinkedList[theList.length*2];
//更新hashTable
for(int i=0;i<theList.length;i++)
theList[i]=new LinkedList<>();
curSize = 0; for(int i=0;i<old.length;i++){
for(AnyType x:old[i])
insert(x);
}
} public void clear(){
for(List l:theList){
l.clear();
}
}
public void remove(AnyType x){
List<AnyType> temp = theList[myHast(x)];
if(temp.contains(x)){
temp.remove(x);
curSize--;
}
}
public boolean contain(AnyType x){
List<AnyType> temp = theList[myHast(x)];
return temp.contains(x);
}
/**
* 计算数据的hash值
* @param x
* @return
*/
private int myHast(AnyType x) {
int hashValue = x.hashCode(); hashValue%=theList.length;
if(hashValue<0)
hashValue+=theList.length;
return hashValue;
} /**
* 返回一个比size大的质数
* @param size
* @return
*/
private int nextPrime(int size) {
if(size%2==0)
size++;
while(!isPrime(size)){
size +=2;
}
return 0;
}
/**
* 判断size是否为质数
* @param size
* @return
*/
private boolean isPrime(int size) {
if(size%2==0||size==1)
return false;
if(size==2 || size==3)
return true;
for(int i=3;i<Math.sqrt(size);i+=2){
if(size%i==0)
return false;
}
return true;
}
}

My集合框架第四弹 HashTable(链表解决冲突)的更多相关文章

  1. Java集合框架的四个接口

    接口 [四个接口  collection  list  set  map 的区别] collection 存储不唯一的无序的数据 list 存储有序的不唯一的数据 set   存储无序的唯一的数据 m ...

  2. Java源码解析——集合框架(四)——LinkedListLinkedList原码分析

    LinkedList源码分析 LinkedList也和ArrayList一样实现了List接口,但是它执行插入和删除操作时比ArrayList更加高效,因为它是基于链表的.基于链表也决定了它在随机访问 ...

  3. Java基础知识强化之集合框架笔记67:Hashtable的实现原理

    至于Hashtable的实现原理,直接参考网友的博客,总结很全面: 深入Java集合学习系列:Hashtable的实现原理

  4. java 集合框架(十四)Queue

    一.概述 Queue一种队列结构集合,用来存储将要进行处理的元素.通常以FIFO的方式排序元素,但这并不是必须的.比如优先度队列就是一个例外,它是以元素的值来排序.但无论怎样,每个Queue的实现都必 ...

  5. My集合框架第三弹 AVL树

    旋转操作: 由于任意一个结点最多只有两个儿子,所以当高度不平衡时,只可能是以下四种情况造成的: 1. 对该结点的左儿子的左子树进行了一次插入. 2. 对该结点的左儿子的右子树进行了一次插入. 3. 对 ...

  6. Java集合框架(四)—— Queue、LinkedList、PriorityQueue

    Queue接口 Queue用于模拟了队列这种数据结构,队列通常是指“先进先出”(FIFO)的容器.队列的头部保存在队列中时间最长的元素,队列的尾部保存在队列中时间最短的元素.新元素插入(offer)到 ...

  7. 一、集合框架(HashMap和Hashtable的区别)

    一.HashMap和Hashtable 都实现了Map接口,都是以key-value形式保存数据. 区别一: HashMap可以存放null Hashtable不能存放null 区别二: HashMa ...

  8. java集合框架之HashMap和Hashtable的区别

    参考http://how2j.cn/k/collection/collection-hashmap-vs-hashtable/692.html#nowhere HashMap和Hashtable的区别 ...

  9. My集合框架第六弹 左式堆

    左式堆(Leftist Heaps)又称作最左堆.左倾堆.左式堆作为堆的一种,保留了堆的一些属性. 第1,左式堆仍然以二叉树的形式构建: 第2,左式堆的任意结点的值比其子树任意结点值均小(最小堆的特性 ...

随机推荐

  1. 对于fmri的设计矩阵构造的一个很直观的解释-by 西南大学xulei教授

    本程序意在解释这样几个问题:完整版代码在本文的最后. 1.实验的设计如何转换成设计矩阵? 2.设计矩阵的每列表示一个刺激条件,如何确定它们? 3.如何根据设计矩阵和每个体素的信号求得该体素对刺激的敏感 ...

  2. 递归神经网络(Recurrent Neural Networks,RNN)

    在深度学习领域,传统的多层感知机(MLP)具有出色的表现,取得了许多成功,它曾在许多不同的任务上——包括手写数字识别和目标分类上创造了记录.甚至到了今天,MLP在解决分类任务上始终都比其他方法要略胜一 ...

  3. 【自动化测试】关于UI自动化的疑问(记录ing)

    1. 数据变动问题导致业务需要增加新的逻辑,这是增加case的健壮性还是浪费时间? 2. 如何做好PO? 不断数据抽离不断优化方法? 3. 如何提高调试代码的效率? /web可以 4. 主管不理解自动 ...

  4. 安装rlwrap错误的问题解决方法

     You need the GNU readline library(ftp://ftp.gnu.org/gnu/readline/ ) to build this program.如果安装rlwra ...

  5. POJ 2249 Binomial Showdown

    // n 个 数 取 k个数的取法// C(n,k) 注意些细节#include <iostream> #include <string> #include<sstrea ...

  6. Windows下配置cygwin和ndk编译环境

    cygwin安装 正确的安装步骤其实很简单:1. 下载setup-86_64.exe 2. 直接从网上下载安装,选择包时,顶部选择“default”不变 3. 搜索make,勾选make,cmake, ...

  7. 本地Git环境配置

    在Git Bash下获取源码时,提示permission denied publickey. 原因是本地帐号配置不正确,解决办法 生成SSH文件 1,进入Git Bash 2,  输入下面文字 ssh ...

  8. Android Lock Screen Orientation

    一些与屏幕有关的基础知识: //这个是手机屏幕的旋转角度 final int rotation = this.getWindowManager().getDefaultDisplay().getOri ...

  9. Twitter Storm: storm的一些常见模式

    这篇文章列举出了storm topology里面的一些常见模式: 流聚合(stream join) 批处理(Batching) BasicBolt 内存内缓存 + fields grouping 组合 ...

  10. 细雨学习笔记:Jmeter上一个请求的结果作为下一个请求的参数--使用正则提取器

    Jmeter接口自动化--使用正则提取器,可以把上一个请求的结果取出来,作为下一个请求的入参