java数据结构之哈希表
数据结构之哈希表
啥是哈希表?
散列表(Hash table,也叫哈希表),是根据关键码值(Key value)而直接进行访问的数据结构。也就是说,它通过把关键码值映射到表中一个位置来访问记录,以加快查找的速度。这个映射函数叫做散列函数,存放记录的数组叫做散列表。
如果没有实际接触过哈希表的实例,及代码,看概念是真的难以理解,下面来看实例
哈希表(散列)-Google 上机题
- 看一个实际需求,google 公司的一个上机题:
- 有一个公司,当有新的员工来报道时,要求将该员工的信息加入(id,性别,年龄,住址…),当输入该员工的 id 时,要求查
找到该员工的 所有信息. - 要求: 不使用数据库,尽量节省内存,速度越快越好=>哈希表(散列)
package cn.ycl.dataStructures.HashTable;
import java.util.Scanner;
//哈希表
public class HashTableDemo{
public static void main(String[] args) {
//创建哈希表
HashTable hashTable = new HashTable(7);
//创建一个简单的菜单
Scanner scanner = new Scanner(System.in);
while (true) {
System.out.println("add:添加员工");
System.out.println("list:查询员工");
System.out.println("exit: 退出");
String key= scanner.next();
switch (key) {
case "add":
System.out.println("请输入id:");
int id=scanner.nextInt();
System.out.println("请输入name:");
String name= scanner.next();
Emp emp = new Emp(id ,name);
hashTable.add(emp);
break;
case "list":
hashTable.list();
break;
case "exit":
scanner.close();
System.exit(0);
break;
default:
break;
}
}
}
}
//创建HashTabble管理多条链表
class HashTable{
private int size;
private EmpLinkedList [] empLinkdedListArray;
//
public HashTable(int size) {
super();
this.size = size;
empLinkdedListArray=new EmpLinkedList[size];
for (int i = 0; i < size; i++) {
empLinkdedListArray[i]=new EmpLinkedList();
}
}
//添加员工
public void add(Emp emp) {
//根据员工id,判断该员工应该添加到那条链表中去
int num=selectLinkList(emp.id);
//将员工加入到对应的链表中
empLinkdedListArray[num].add(emp);
}
//显示员工
public void list() {
for (int i = 0; i < size; i++) {
empLinkdedListArray[i].list(i);
}
}
// 散列函数,使用简单的取模法
public int selectLinkList(int id) {
// 返回的取余代表将员工插入到哈希表中的哪个链表中
return id % size;
}
}
class Emp {
int id;
String name;
Emp next;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Emp getNext() {
return next;
}
public void setNext(Emp next) {
this.next = next;
}
public Emp() {
super();
}
public Emp(int id, String name) {
super();
this.id = id;
this.name = name;
}
}
class EmpLinkedList {
Emp head;
//添加员工
public void add(Emp emp) {
// 当前链表为空时
if (head == null) {
head= emp;
return;
}
Emp temp=head;
while (true) {
// 持续查找,直到找到链表末尾
if (temp.next==null) {
break;
}
temp=temp.next;
}
temp.next=emp;
}
// 遍历员工
public void list(int no) {
Emp temp = head;
if (head== null) {
System.out.println("第"+(no+1)+"条链表为空");
return;
}
System.out.print("第"+(no+1)+"条链表的信息为:");
while (true) {
System.out.printf("=>id=%d, name=%s\t", temp.id, temp.name);
System.out.println();
if (temp.next == null) {
break;
}
temp = temp.next;// 后移,遍历
}
}
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 【自荐】一款简洁、开源的在线白板工具 Drawnix