散列表描述

</pre><p><pre name="code" class="java">/*
 * 散列表
 */
public class HashTable {
	
	public static final int CAPACITY = 10;
	private Node[] value = null;
	
	public static void main(String[] args) {
		HashTable hashtable = new HashTable();
		hashtable.insertData(22);
		hashtable.insertData(22);
		hashtable.insertData(123);
		hashtable.insertData(436);
		hashtable.insertData(55);
		hashtable.insertData(157);
		hashtable.insertData(235);
		hashtable.insertData(256);
		hashtable.insertData(525);
		hashtable.insertData(724);
		hashtable.insertData(278);
		hashtable.insertData(209);
		hashtable.insertData(67);
		hashtable.insertData(54);
		hashtable.insertData(546);
		hashtable.insertData(350);
		hashtable.insertData(101);
		hashtable.insertData(23);
		System.out.println("刪除前的散列表:");
		hashtable.printHashTable();
		hashtable.deleteData(55);
		hashtable.deleteData(350);
		System.out.println("刪除後的散列表:");
		hashtable.printHashTable();

	}
	
	public HashTable() {
		value = new Node[CAPACITY];
	}
	
	//在哈希表中查找數據
	private Node searchData(int data) {
		Node node = value[data % CAPACITY];
		if(null == node) {
			return null;
		}
		
		while(node != null) {
			if(data == node.key) {
				return node;
			}
			node = node.next;	
		}
		return null;
	}
	
	//插入數據
	private boolean insertData(int data) {
		Node nd = value[data % CAPACITY];
		if(null == nd) {
			Node node = new Node(data);
			value[data % CAPACITY] = node;
			return true;
		}
		//如果已經有這個值了,插入無效
		if(null != searchData(data)) {		
			return false;
		}
		while(nd.next != null) {
			nd = nd.next;
		}
		nd.next = new Node(data);
		return true;
	}
	
	private boolean deleteData(int data) {
		Node head = value[data % CAPACITY];
		Node node = searchData(data);
		
		if(null == head || null == node) {
			return false;
		}

		if(node == head) {
			//刪除時要注意,head只是棧內存中的引用
			value[data % CAPACITY] = head.next;		
			return false;
		}
		while(node != head.next) {
			head = head.next;
		}
		head.next = node.next;
		return true;
	}
	
	void printHashTable()
	{
		int i=0;

	    System.out.println("[Hash idx]     [value]");
	    do {
	    	System.out.print("   "+i+"-------------");
	        if(null == value[i]) {
	            i++;
	            System.out.println("NULL");
	            continue;
	        }
	        Node node = value[i];

	        while(node != null) {
	        	System.out.print(node.key+" ");
	            node = node.next;
	        }
	        System.out.println();
	        i++;
	    } while (i<10);

        System.out.println();
	}
	
	private static class Node {
		int key = 0;
		Node next = null;
		public Node(int key) {
			this.key = key;
		}	
	}
}

運行結果爲:

刪除前的散列表:
[Hash idx]     [value]
   0-------------350 
   1-------------101 
   2-------------22 
   3-------------123 23 
   4-------------724 54 
   5-------------55 235 525 
   6-------------436 256 546 
   7-------------157 67 
   8-------------278 
   9-------------209 

刪除後的散列表:
[Hash idx]     [value]
   0-------------NULL
   1-------------101 
   2-------------22 
   3-------------123 23 
   4-------------724 54 
   5-------------235 525 
   6-------------436 256 546 
   7-------------157 67 
   8-------------278 
   9-------------209 





發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章