用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; } }