用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. 用Creator实现一个擀面的效果

    先上几张效果图 怎么实现的呢? 节点介绍 1是背景图,可以忽略:2 是准备好的面团:3 是擀好的面饼先隐藏:4 是需要绘制的节点:5 是擀面杖. 制作开始 首先在view上挂一个mask,并且设置为模 ...

  2. 实现客户端与服务端之间传输json数据

    步骤:创建数据库,并创建表.利用myeclipse创建新工程,利用JDBC实现java操纵数据库.实现客户端类,服务端类.具体实现:创建数据表create table usertable( usern ...

  3. hive sql 解析json

    在hive中会有很多数据是用json格式来存储的,而我们用数据的时候又必须要将json格式的数据解析成为正常的数据,今天我们就来聊聊hive中是如何解析json数据的. 下面这张表就是json格式的表 ...

  4. 整合Lettuce Redis

    SpringBoot 是为了简化 Spring 应用的创建.运行.调试.部署等一系列问题而诞生的产物,自动装配的特性让我们可以更好的关注业务本身而不是外部的XML配置,我们只需遵循规范,引入相关的依赖 ...

  5. python学习_Linux系统的常用命令(二)

    linux基本命令: 1.ls 的详细操作: ls - l : 以列表方式显示文件的详细信息 ls -l -h: 以人性化的方式显示文件的大小 ls -l -h -a 显示所有的目录和文件,包括隐藏文 ...

  6. Python3笔记005 - 2.2 保留字与标识符

    第2章 python语言基础 python语法特点 保留字与标识符 变量 数据类型 运算符 输入和输出 2.2 保留字与标识符 2.2.1 保留字 查看python保留字 import keyword ...

  7. Linux傻瓜式七步完美安装Python3.7

    1 安装依赖包 yum -y install zlib-devel bzip2-devel openssl-devel ncurses-devel sqlite-devel readline-deve ...

  8. java架构-一些设计上的基本常识

    最近给团队新人讲了一些设计上的常识,可能会对其它的新人也有些帮助, 把暂时想到的几条,先记在这里. 1.API与SPI分离 框架或组件通常有两类客户,一个是使用者,一个是扩展者. API(Applic ...

  9. 猿灯塔:最详细Dubbo相关面试题!

    1.Dubbo是什么? Dubbo是阿里巴巴开源的基于 Java 的高性能 RPC 分布式服务框架,现已成为 Apache 基金会孵化项目. 面试官问你如果这个都不清楚,那下面的就没必要问了. 官网: ...

  10. LESS 原理,一款css的预处理程序Less的使用

    ​Less一种动态样式语言,LESS将CSS赋予了动态语言的特性,如变量,继承,运算,函数...LESS 既可以在客户端上运行 (支持IE 6+, Webkit, Firefox),也可以借助Node ...