用java代码完成哈希表数据结构的简单实现, 以公司雇员的添加修改作为模拟实例 具体代码如下:

package com.seizedays.hashtable;

import java.util.Scanner;

public class HashTableDemo {
public static void main(String[] args) {
//创建一个哈希表
HashTable hashTable = new HashTable(7); String key = "";
Scanner scanner = new Scanner(System.in);
while (true) {
System.out.println();
System.out.println("add: 添加雇员");
System.out.println("list: 显示雇员");
System.out.println("find: 查找雇员");
System.out.println("exit: 退出系统");
key = scanner.next(); switch (key) {
case "add":
System.out.println("输入id");
int id = scanner.nextInt();
System.out.println("输入名字");
String name = scanner.next();
Emp emp = new Emp(id, name);
hashTable.add(emp);
break;
case "list":
hashTable.list();
break; case "find":
System.out.println("请输入雇员id");
int id2 = scanner.nextInt();
hashTable.findEmpById(id2);
break; case "exit":
scanner.close();
System.exit(0);
default:
break;
}
} }
} //雇员类
class Emp {
public int id;
public String name;
public Emp next; //默认为空 public Emp(int id, String name) {
super();
this.id = id;
this.name = name;
}
} //创建Has他Table 管理链表
class HashTable {
private EmpLinkedList[] empLinkedListArray;
private int size; public HashTable(int size) {
// 初始化链表
this.size = size;
empLinkedListArray = new EmpLinkedList[size]; for (int i = 0; i < size; i++) {
empLinkedListArray[i] = new EmpLinkedList();
}
} //添加新员工
public void add(Emp emp) {
//根据员工的id 得到该员工应该添加到哪个链表
int empLinkListNo = hashFun(emp.id); //将Emp添加到对应的链表中
empLinkedListArray[empLinkListNo].add(emp); }
//编写一个散列函数 使用一个简单的取模法来处理
public int hashFun(int id) {
return id % size;
} //遍历所有的链表
public void list() {
for (int i = 0; i < size; i++) {
empLinkedListArray[i].list(i); }
} //根据输入的id 查找雇员
public void findEmpById(int id){
int no = hashFun(id);
Emp emp = empLinkedListArray[no].findEmpById(id);
if (emp != null) {
System.out.printf("在第%d条链表中找到该雇员, 雇员id = %d", no + 1, id);
}else {
System.out.println("在hash表中没有找到该雇员");
}
} } // 创建一个EmpLinkedList
class EmpLinkedList {
// 头指针 执行第一个Emp 因此我们的链表的head是指向第一个雇员的
private Emp head; //默认为空 //添加雇员 假定雇员添加到链表的最后位置
public void add(Emp emp) {
//如果添加的是第一个雇员
if (head == null) {
head = emp;
return;
}
//如果不是第一个雇员 则使用辅助指针帮助定位到最后
Emp curEmp = head;
while (curEmp.next != null) {
curEmp = curEmp.next;
} //退出时 直接将Emp加入链表
curEmp.next = emp; } //遍历链表的雇员信息
public void list(int no) {
if (head == null) {
System.out.printf("\n第" + (no + 1) + "个链表为空");
return;
}
System.out.print("\n第" + (no + 1) + "个链表信息为:");
Emp curEmp = head;
while (true) {
System.out.printf("=> id = %d name = %s \t", curEmp.id, curEmp.name);
if (curEmp.next == null) {
break;
}
curEmp = curEmp.next;
}
} //根据id查找雇员
// 查找到 则返回Emp 没有找到 返回null
public Emp findEmpById(int id){
if (head == null) {
System.out.println("链表为空");
return null;
} Emp curEmp = head;
while (true){
if (curEmp.id == id){
break;
} if (curEmp.next == null) {
curEmp = null;
break;
}
curEmp = curEmp.next;
} return curEmp;
} }

使用java实现希表的基础功能的更多相关文章

  1. Java哈希表入门

    Java哈希表(Hash Table) 最近做题经常用到哈希表来进行快速查询,遂记录Java是如何实现哈希表的.这里只简单讲一下利用Map和HashMap实现哈希表. 首先,什么是Map和HashMa ...

  2. java——哈希表 HashTable

    在一个类中重写hashCode()和equals() package Date_pacage.hash; public class Student { private int grade; priva ...

  3. Java 哈希表运用-LeetCode 1 Two Sum

    Given an array of integers, find two numbers such that they add up to a specific target number. The ...

  4. java哈希表(线性探测哈希表。链式哈希表)

    哈希表(散列表) 通过哈希函数使元素的存储位置与它 的关键码之间能够建立一一映射的关系,在查找时可以很快找到该元素. 哈希表hash table(key,value) 的做法其实很简单,就是把Key通 ...

  5. Java 哈希表(google 公司的上机题)

    1 哈希表(散列)-Google 上机题 1) 看一个实际需求,google 公司的一个上机题: 2) 有一个公司,当有新的员工来报道时,要求将该员工的信息加入(id,性别,年龄,住址..),当输入该 ...

  6. Java 哈希表

    public int firstUniqChar(String s){ int[] freq=new int[26]; for(int i=0;i<s.length();i++){ freq[s ...

  7. 【算法】哈希表的诞生(Java)

    参考资料 <算法(java)>                           — — Robert Sedgewick, Kevin Wayne <数据结构>       ...

  8. Python 字典和集合基于哈希表实现

    哈希表作为基础数据结构我不多说,有兴趣的可以百度,或者等我出一篇博客来细谈哈希表.我这里就简单讲讲:哈希表不过就是一个定长数组,元素找位置,遇到哈希冲突则利用 hash 算法解决找另一个位置,如果数组 ...

  9. 浅谈MatrixOne如何用Go语言设计与实现高性能哈希表

    目录 MatrixOne数据库是什么? 哈希表数据结构基础 哈希表基本设计与对性能的影响 碰撞处理 链地址法 开放寻址法 Max load factor Growth factor 空闲桶探测方法 一 ...

随机推荐

  1. python检测“无内容”图片

    思路1:通过图像熵检测,“无内容”图像熵较小,可通过设置阈值检测“无内容”图像,计算图像熵可参考:https://www.cnblogs.com/niulang/p/12195152.html 思路2 ...

  2. dart快速入门教程 (5)

    5.函数 5.1.函数定义 语法: 返回值类型 函数名(参数类型 参数1, 参数类型 参数2,...) { // 函数体 return '返回值' } 举例: void main() { print( ...

  3. 6.30集训模拟赛4(炸裂的一天qwq)

    T1浇水: 题目描述 在一条长n米,宽m米米的长方形草地上放置着k个喷水装置.假设长方形草地的坐标范围为[ 0 , 0 ] ~ [ n , m ],那么第 i 个喷水装置的位置为(ai,m/2),也就 ...

  4. HotSpot的类模型(2)

    在前一篇文章 HotSpot的二分模型中已经讲过,HotSpot采用了OOP-Klass模型描述Java的类和对象.Klass模型采用Klass类及相关子类来表示具体的Java类,可以理解这些类为Ja ...

  5. 5年前端经验小伙伴教你纯css3实现饼状图

    有一些网页中,有时候会碰到饼状图的需求,比如统计图表,进度指示器,定时器等,实现方式也是各种各样,现在也有不少现成的js库,可以直接拿来使用,方便很多.这里笔者为大家演示一种纯css实现饼状图效果的方 ...

  6. html中为何经常使用<i>标签来作为小图标呢?

    很多网站都是习惯使用<i></i>来代表小图标?而实际上用 <i> 元素做图标在语义上是不正确的(虽然看起来像 icon 的缩写),那么用<i>表示小i ...

  7. 哎,老了之display-box

    哎,不想吐槽自己了,表示已远远落后,从今天起开始恶补吧,来一个实例 <html> <head> <meta name="generator" cont ...

  8. windows快速安装redis

    下载地址:https://github.com/microsoftarchive/redis/releases 下载解压,命令行:redis-server.exe redis.windows.conf

  9. CountDownLatch 线程工具类

    CountDownLatch:概念是,允许一个或多个线程等待其他线程完成操作: 在线程基础知识中,学习过线程的join方法,当前线程阻塞等待join线程执行完毕才能执行: 测试代码如下: public ...

  10. POJ3057 Evacuation 二分图匹配+最短路

    POJ3057 Evacuation 二分图匹配+最短路 题目描述 Fires can be disastrous, especially when a fire breaks out in a ro ...