用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. 小白—职场之Java基础篇

    java基础篇 java基础 目录 1.java是一种什么语言,jdk,jre,jvm三者的区别 2.java 1.5之后的三大版本 3.java跨平台及其原理 4.java 语言的特点 5.什么是字 ...

  2. 基于jQuery的打字机函数

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  3. 【UVA11383】 Golden Tiger Claw 【二分图KM算法(板子)】

    题目 题目传送门:https://www.luogu.com.cn/problem/UVA11383 分析 最近刚刚学了二分图,然后来了一个这样的题,看完题意之后,稍微想一想就能想出来是一个二分图,然 ...

  4. Vue 封装axios(四种请求)及相关介绍(十三)

    Vue 封装axios(四种请求)及相关介绍 首先axios是基于promise的http库 promise是什么? 1.主要用于异步计算 2.可以将异步操作队列化,按照期望的顺序执行,返回符合预期的 ...

  5. 在 Visual Studio 市场中发布项目扩展

    比较不错的开源项目中,尤其是类似于AbpNext这种级别的项目,我们都想要快速的尝试,如何提供快速给开发者提供模板是我们的一大难题.不过在VisualStudio中并没有这么难. 一.本地发布插件 就 ...

  6. suprious weakup

    线程wait情况下,有可能没有中断,没有唤醒,而返回, 称为spurious wakeup. wait在循环中,通过对condition的判断来决定是否继续wait. 概率比较低.

  7. YAML & JSON &XML如何选择

    前言 本文翻译https://www.csestack.org/yaml-vs-json-vs-xml-difference/,下文会针对当前现有的数据序列化语言做下梳理.重点突出YAML是什么,优缺 ...

  8. 使用LLDB和debugserver对ios程序进行调试

    在没有WIFI的情况下,使用USB连接IOS设备,使用辅助插件usbmuxd来辅助调试.我其实也想用wifi调试,奈何公司的wifi绑定了mac地址,而我又使用的是黑苹果虚拟机,使用桥接的方式修改网段 ...

  9. C#联合WINCC之数据通信

    [公众号dotNet工控上位机:thinger_swj] 在工控领域中,WINCC仍然占有很大的市场份额.很多时候我们说学习C#开发上位机可以取代传统的组态软件,两者就像冤家一样,然而,即使是冤家,也 ...

  10. 一个例子理解c++函数模板的编译

    一.例子 template <typename T> inline void callWithMax(const T& a, const T& b){ f(a > b ...