使用java实现希表的基础功能
用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实现希表的基础功能的更多相关文章
- Java哈希表入门
Java哈希表(Hash Table) 最近做题经常用到哈希表来进行快速查询,遂记录Java是如何实现哈希表的.这里只简单讲一下利用Map和HashMap实现哈希表. 首先,什么是Map和HashMa ...
- java——哈希表 HashTable
在一个类中重写hashCode()和equals() package Date_pacage.hash; public class Student { private int grade; priva ...
- Java 哈希表运用-LeetCode 1 Two Sum
Given an array of integers, find two numbers such that they add up to a specific target number. The ...
- java哈希表(线性探测哈希表。链式哈希表)
哈希表(散列表) 通过哈希函数使元素的存储位置与它 的关键码之间能够建立一一映射的关系,在查找时可以很快找到该元素. 哈希表hash table(key,value) 的做法其实很简单,就是把Key通 ...
- Java 哈希表(google 公司的上机题)
1 哈希表(散列)-Google 上机题 1) 看一个实际需求,google 公司的一个上机题: 2) 有一个公司,当有新的员工来报道时,要求将该员工的信息加入(id,性别,年龄,住址..),当输入该 ...
- Java 哈希表
public int firstUniqChar(String s){ int[] freq=new int[26]; for(int i=0;i<s.length();i++){ freq[s ...
- 【算法】哈希表的诞生(Java)
参考资料 <算法(java)> — — Robert Sedgewick, Kevin Wayne <数据结构> ...
- Python 字典和集合基于哈希表实现
哈希表作为基础数据结构我不多说,有兴趣的可以百度,或者等我出一篇博客来细谈哈希表.我这里就简单讲讲:哈希表不过就是一个定长数组,元素找位置,遇到哈希冲突则利用 hash 算法解决找另一个位置,如果数组 ...
- 浅谈MatrixOne如何用Go语言设计与实现高性能哈希表
目录 MatrixOne数据库是什么? 哈希表数据结构基础 哈希表基本设计与对性能的影响 碰撞处理 链地址法 开放寻址法 Max load factor Growth factor 空闲桶探测方法 一 ...
随机推荐
- 入门大数据---Flink核心概念综述
一.Flink 简介 Apache Flink 诞生于柏林工业大学的一个研究性项目,原名 StratoSphere .2014 年,由 StratoSphere 项目孵化出 Flink,并于同年捐赠 ...
- Java基础:变量、常量、作用域
JAVA基础:变量.常量.作用域 变量:可以变化的量.Java是强类型语言,每个变量都必须声明类型. Java变量是程序中最基本的存储单元,要素包括变量名,类型和作用域. //类变量 static s ...
- Kubernetes 中 搭建 EFK 日志搜索中心
简介 Elastic 官方已经发布了Elasticsearch Operator ,简化了 elasticsearch 以及 kibana的部署与升级,结合 fluentd-kubernetes-da ...
- navicat连接vagrant中的数据库
- python unittest自动测试框架
编写函数或者类时进行测试,确保代码正常工作 python unittest 模块提供了代码测试工具.按照定义测试包括两部分:管理测试依赖库的代码(称为‘固件’)和测试本身. 单元测试用于核实函数的某 ...
- 每天一个LINUX命令(pwd)
每天一个LINUX命令(pwd) 基本信息 pwd: /bin/pwd,显示当前路径的绝对路径 语法:pwd 应用程序位置 which pwd PWD作用 pwd --help ...
- node解压压缩包以及压缩图片
node解压压缩包以及压缩图片 首先保证电脑安装node环境,下载地址:http://nodejs.cn //可以打开一个dos窗口输入node -v进行确认是否安装成功 C:\ > node ...
- JavaScript动画实例:递归分形图动态展示
在“JavaScript图形实例:SierPinski三角形” 和“JavaScript图形实例:Levy曲线及其变形”等文章中我们介绍了通过递归生成分形图形的方法.我们可以将绘制的分形图形每隔一定的 ...
- 进阿里真的这么难?P8大佬告诉你,你和阿里之间缺的只是这份笔记
一转眼今年已经到六月份了,在这个过去的半年里有人选择了安稳,有的人偏偏不... 最近小编就有个朋友,去面了个[P8 级架构师],也算是摸摸行情,为后面的一些安排提前做好规划~ 先给大家介绍一下我这个朋 ...
- css hack原理及常用hack
原理:利用不同浏览器对CSS的支持和解析结果不一样编写针对特定浏览器样式.常见的hack有1)属性hack.2)选择器hack.3)IE条件注释 IE条件注释:适用于[IE5, IE9]常见格式如下 ...