哈希表

解释

哈希表是一种根据关键码去寻找值的数据映射结构,该结构通过把关键码映射的位置去寻找存放值的地方

内存结构分析图

  • 1、定义一个类为结点,存储的信息
  • 2、定义链表的相关操作
  • 3、定义一个数组存储多条链表

各个部分的分析

1、结点:

//定义链表的节点

class Student {
public int id;
public String name;
public String sex;
public Student next;//指向下一个节点 public Student(int id, String name, String sex) {
this.id = id;
this.name = name;
this.sex = sex;
} }

2、定义链表
(这里和单链表不同的一点是头节点的初始化,在单链表中为了确定链表的开始位置,设置head结点不存储任何数据,只是用来确定链表开始的位置。在哈希表中,链表的头位置存储在数组中,为链表的开始,可以存储数据)


class linkList {
private Student head;//定义一个头节点,下一个指向为null //增加操作
public void add(Student student) {
//1、当前链表为空,则直接将节点加在后边
if (head == null) {
head = student;
return;
} Student temp = head;//定义辅助节点
while (true) {
if (temp.next == null) {
break;
}
temp = temp.next;//移动节点
}
temp.next = student;//将新的节点链接到链表尾
} //遍历节点
public void list() {
if (head == null) {
System.out.println("链表为空");
return;
} Student temp = head;
while (true) {
System.out.printf("==>id=%d name=%s sex=%s\t", temp.id, temp.name, temp.sex);
if (temp.next == null) {
break;
} temp = temp.next;
}
System.out.println(""); } //根据id查询某个学生的相关信息
public void getStudentById(int id){
if(head==null){
return;//当前链表没有
} Student temp=head;//辅助节点
while (true){ if(temp.id==id){
System.out.println("id为"+id+"学生的信息为:id:"+temp.id+" 姓名:"+temp.name+" 性别:"+temp.sex);
break;
}
if(temp.next==null){
return;//该链表不存在
}
temp=temp.next;//指向下一个节点
} } }

3、定义储存多条链表
(注意的点:需要初始化每一条存储在数组中的链表。使用for循环)

class ArrayHashTable {
public int sizeMax;
public linkList[] hashtabl; //初始化数组
public ArrayHashTable(int sizeMax) {
super();
this.sizeMax = sizeMax;
hashtabl = new linkList[this.sizeMax];
for (int i = 0; i < sizeMax; i++) {
hashtabl[i] = new linkList(); }
} //添加数据
public void addArray(Student student) {
int index = fun(student.id);
hashtabl[index].add(student);
} //定义一个散列函数
public int fun(int id) {
return id % 10;
} //遍历哈希表
public void list1() {
for (int i = 0; i < hashtabl.length; i++) {
System.out.printf("当前第%d链表信息:", i + 1);
hashtabl[i].list();
}
} //查询某个学生的id
public void getStudentById(int id){
for (int i = 0; i < sizeMax; i++) {
hashtabl[i].getStudentById(id); } } }

代码实现

举例:

package com.zheng.demo6;

public class MyHashTable {
public static void main(String[] args) {
//定义几个节点
Student student1 = new Student(1, "小明", "女");
Student student2 = new Student(2, "小红", "女");
Student student3 = new Student(3, "小青", "女");
Student student4 = new Student(4, "小黑", "男");
Student student5 = new Student(5, "小刚", "男");
Student student6 = new Student(11, "李白", "男");
Student student7 = new Student(13, "张三", "男");
Student student8 = new Student(23, "李四", "男");
Student student9 = new Student(10, "麻子", "男"); ArrayHashTable hashTable = new ArrayHashTable(8);
hashTable.addArray(student1);
hashTable.addArray(student2);
hashTable.addArray(student3);
hashTable.addArray(student4);
hashTable.addArray(student5);
hashTable.addArray(student6);
hashTable.addArray(student7);
hashTable.addArray(student8);
hashTable.addArray(student9); System.out.println("遍历哈希表");
hashTable.list1();
System.out.println("查询数据");
hashTable.getStudentById(23); } } class ArrayHashTable {
public int sizeMax;
public linkList[] hashtabl; //初始化数组
public ArrayHashTable(int sizeMax) {
super();
this.sizeMax = sizeMax;
hashtabl = new linkList[this.sizeMax];
for (int i = 0; i < sizeMax; i++) {
hashtabl[i] = new linkList(); }
} //添加数据
public void addArray(Student student) {
int index = fun(student.id);
hashtabl[index].add(student);
} //定义一个散列函数
public int fun(int id) {
return id % 10;
} //遍历哈希表
public void list1() {
for (int i = 0; i < hashtabl.length; i++) {
System.out.printf("当前第%d链表信息:", i + 1);
hashtabl[i].list();
}
} //查询某个学生的id
public void getStudentById(int id){
for (int i = 0; i < sizeMax; i++) {
hashtabl[i].getStudentById(id); } } } class linkList {
private Student head;//定义一个头节点,下一个指向为null //增加操作
public void add(Student student) {
//1、当前链表为空,则直接将节点加在后边
if (head == null) {
head = student;
return;
} Student temp = head;//定义辅助节点
while (true) {
if (temp.next == null) {
break;
}
temp = temp.next;//移动节点
}
temp.next = student;//将新的节点链接到链表尾
} //遍历节点
public void list() {
if (head == null) {
System.out.println("链表为空");
return;
} Student temp = head;
while (true) {
System.out.printf("==>id=%d name=%s sex=%s\t", temp.id, temp.name, temp.sex);
if (temp.next == null) {
break;
} temp = temp.next;
}
System.out.println(""); } //根据id查询某个学生的相关信息
public void getStudentById(int id){
if(head==null){
return;//当前链表没有
} Student temp=head;//辅助节点
while (true){ if(temp.id==id){
System.out.println("id为"+id+"学生的信息为:id:"+temp.id+" 姓名:"+temp.name+" 性别:"+temp.sex);
break;
}
if(temp.next==null){
return;//该链表不存在
}
temp=temp.next;//指向下一个节点
} } } //定义链表的节点 class Student {
public int id;
public String name;
public String sex;
public Student next;//指向下一个节点 public Student(int id, String name, String sex) {
this.id = id;
this.name = name;
this.sex = sex;
} } // public void add(Student student) {
// //1、当前链表为空,则直接将节点加在后边
// if (head == null) {
// head = student;
// }
// Student temp = head;//定义辅助节点
// while (true) {
// if (temp.next == null) {
// temp.next = student;
// break;//遍历到链表的尾部
// }
// temp = temp.next;//移动节点
// }
//
// }

数据结构中的哈希表(java实现)利用哈希表实现学生信息的存储的更多相关文章

  1. 深入理解PHP内核(六)哈希表以及PHP的哈希表实现

    原文链接:http://www.orlion.ga/241/ 一.哈希表(HashTable) 大部分动态语言的实现中都使用了哈希表,哈希表是一种通过哈希函数,将特定的键映射到特定值得一种数据 结构, ...

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

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

  3. 数据结构 哈希表(Hash Table)_哈希概述

    哈希表支持一种最有效的检索方法:散列. 从根来上说,一个哈希表包含一个数组,通过特殊的索引值(键)来访问数组中的元素. 哈希表的主要思想是通过一个哈希函数,在所有可能的键与槽位之间建立一张映射表.哈希 ...

  4. 【二分答案】【哈希表】【字符串哈希】bzoj2946 [Poi2000]公共串

    二分答案,然后搞出hash值扔到哈希表里.期望复杂度O(n*log(n)). <法一>next数组版哈希表 #include<cstdio> #include<cstri ...

  5. java操作数据库,以页面显示学生信息为例

    该部分内容实现的功能主要是:从数据库中查询数据并展示到页面,在页面中新增数据信息,在页面中修改数据信息,在页面中删除数据信息. =================stuList.jsp======== ...

  6. java web利用jsp完成简单的学生管理系统

    index.jsp <%@ page language="java" import="java.sql.*" pageEncoding="utf ...

  7. 彻底弄明白之数据结构中的排序七大算法-java实现

    package ds; /* * author : codinglion * contact: chenyakun@foxmail.com */ import java.util.Random; pu ...

  8. 哈希表-java

    import java.util.HashMap; import java.util.Iterator; public class JavaHashMap { public static void m ...

  9. Java学习:Set接口与HashSet集合存储数据的结构(哈希表)

    Set接口 java.util.Set接口 extends Collection接口 Set接口的特点: 不允许存储重复的元素 没有索引,没有带索引的方法,也不能使用普通的for循环遍历 java.u ...

随机推荐

  1. 4.直方图介绍和使用|MySQL索引学习

    GreatSQL社区原创内容未经授权不得随意使用,转载请联系小编并注明来源. 目录 一.导读 二.步骤 2.1 SQL语句 2.2 直方图案例 2.3 查看直方图统计信息 2.3 直方图分类 2.4 ...

  2. 从零开始Blazor Server(11)--编辑用户

    用户编辑和角色编辑几乎一模一样,这里先直接贴代码. @page "/user" @using BlazorLearn.Entity @using Furion.DataEncryp ...

  3. 元数据治理利器 - Apache Atlas

    一.功能简介 Atlas 是一组可扩展的核心基础治理服务,使企业能够高效地满足其在 Hadoop 中的合规性要求,并允许与整个企业数据生态系统集成.Apache Atlas 为组织提供开放的元数据管理 ...

  4. Codeforces 1715E - Long Way Home

    又是废掉的一个div2啊 第一次在学校熬夜打cf,开心还看到了自己最喜欢的斜率优化ohhh 链接 :E - Long Way Home 看到那个平方就可以靠感觉认为是斜率优化了.... 感觉似不似有点 ...

  5. 读取图片文件MetaFile放入Windows剪切板

    前言 前段时间群里有个小伙在工作中遇到一个问题,透明的图片存入剪切板在粘贴到adobe PDF中出现不透明问题但是粘贴到Excel可以,还有就是从excel复制再粘贴到PDF也是可以.小伙在群里发了两 ...

  6. CF453C Little Pony and Summer Sun Celebration(构造、贪心(?))

    CF453C Little Pony and Summer Sun Celebration 题解 这道题要求输出任意解,并且路径长度不超过4n就行,所以给了我们乱搞构造的机会. 我这里给出一种构造思路 ...

  7. 【PostgreSQL】PostgreSQL 15移除了Stats Collector

    试用即将发行的PostgreSQL 15的人会发现少了一个后台进程:​ postgres 1710 1 0 04:03 ? 00:00:00 /usr/pgsql-15/bin/postmaster ...

  8. 巧用 transition 实现短视频 APP 点赞动画

    在各种短视频界面上,我们经常会看到类似这样的点赞动画: 非常的有意思,有意思的交互会让用户更愿意进行互动. 那么,这么有趣的点赞动画,有没有可能使用纯 CSS 实现呢?那当然是必须的,本文,就将巧妙的 ...

  9. QPainter. QpaintDevice 绘图设备

    QPaintDevice 绘图设备 1 QPixmap QImage Qbitmap(黑白色) QPicture QWidget 2 QPixmap 对不同平台做了显示优化  fill(填充颜色) Q ...

  10. Android的Handler线程切换原理

    Handler是我们在开发中经常会接触到的类,因为在Android中,子线程一般是不能更新UI的. 所以我们会使用Handler切换到主线程来更新UI,那Handler是如何做到实现不同线程之间的切换 ...