intTypePromotion=1
zunia.vn Tuyển sinh 2024 dành cho Gen-Z zunia.vn zunia.vn
ADSENSE

Cấu trúc dữ liệu : BẢNG BĂM (HASH TABLE) part 3

Chia sẻ: Alfhau Sdjfka | Ngày: | Loại File: PDF | Số trang:5

477
lượt xem
61
download
 
  Download Vui lòng tải xuống để xem tài liệu đầy đủ

NODE hashtable[M]; //Khai bao bang bam Cài đặt bảng băm dùng phương pháp kết nối hợp nhất: 2.4.3. Bảng băm với phương pháp dò tuần tự Mô tả: - Cấu trúc dữ liệu: Bảng băm trong trường hợp này được cài đặt bằng danh sách kề có M phần tử, mỗi phần tử của bảng băm là một mẫu tin có một trường key để chứa khoá của phần tử. Khi khởi động bảng băm thì tất cả trường key được gán

Chủ đề:
Lưu

Nội dung Text: Cấu trúc dữ liệu : BẢNG BĂM (HASH TABLE) part 3

  1. NODE hashtable[M]; //Khai bao bang bam C ài đặt bảng băm dùng phương pháp kết nối hợp nhất: 2.4.3. Bảng băm với phương pháp dò tuần tự Mô tả: - Cấu trúc dữ liệu: Bảng băm trong trường hợp này được cài đặt bằng danh sách kề có M phần tử, mỗi phần tử của bảng băm là một mẫu tin có một trường key để chứa khoá của phần tử. Khi khởi động bảng băm thì tất cả trường key được gán N ullKey; - K hi thêm phần tử có khoá key vào bảng băm, hàm băm h(key) sẽ xác định địa chỉ i trong khoảng từ 0 đến M-1: · N ếu chưa bị xung đột thì thêm phần tử mới vào địa chỉ này. · N ếu bị xung đột thì hàm băm lại lần 1, hàm h1 sẽ xét địa chỉ kế tiếp, nếu lại bị xung đột thì hàm băm thì hàm băm lại lần 2, hàm h2 sẽ xét địa chỉ kế tiếp nữa, …, và quá trình cứ thế cho đến khi nào tìm đ ược địa chỉ trống và thêm phần tử mới vào địa chỉ này. - K hi tìm một phần tử có khoá key trong bảng băm, hàm băm h(key) sẽ xác định địa chỉ i trong khoảng từ 0 đến M-1, tìm phần tử khoá key trong bảng băm xuất phát từ địa chỉ i. H àm băm lại lần i được biểu diễn bằng công thức sau: f(key)=(f(key)+i) %M với f(key) là hàm băm chính của bảng băm. Lưu ý đ ịa chỉ dò tìm kế tiếp là đ ịa chỉ 0 nếu đã dò đến cuối bảng. G iả sử, khảo sát bảng băm có cấu trúc như sau: - Tập khóa K: tập số tự nhiên - Tập địa chỉ M: gồm 10 địa chỉ (M={0, 1, …, 9} - H àm băm h(key) = key % 10. 11
  2. H ình thể hiện thêm các nut 32, 53, 22, 92, 17, 34, 24, 37, 56 vào bảng băm. 0 NULL 0 NULL 0 NULL 0 NULL 0 56 1 NULL 1 NULL 1 NULL 1 NULL 1 NULL 2 32 2 32 2 32 2 32 2 32 3 53 3 53 3 53 3 53 3 53 4 NULL 4 22 4 22 4 22 4 22 5 NULL 5 92 5 92 5 92 5 92 6 NULL 6 NULL 6 34 6 34 6 34 7 NULL 7 NULL 7 17 7 17 7 17 8 NULL 8 NULL 8 NULL 8 24 8 24 9 NULL 9 NULL 9 NULL 9 37 9 37 K hai báo cấu trúc bảng băm: #define NULLKEY –1 #define M 100 struct node { int key; //khoa cua nut tren bang bam }; struct node hashtable[M]; //Khai bao bang bam co M nut C ài đặt bảng băm dùng phương pháp dò tuyến tính: 12
  3. 2.4.4. Bảng băm với phương pháp dò bậc hai Mô tả: - Bảng băm trong trường hợp này được cài đ ặt bằng danh sách kề có M phần tử, m ỗi phần tử của bảng băm là một mẫu tin có một trường key để chứa khóa các phần tử. - K hi khởi động bảng băm thì tất cả trường key bị gán NULLKEY. K hi thêm phần tử có khóa key vào bảng băm, hàm băm h(key) sẽ xác định địa chỉ i trong khoảng từ 0 đến M-1. · N ếu chưa bị xung đột thì thêm phần tử mới vào địa chỉ i này. · N ếu bị xung đột thì hàm băm lại lần 1 h1 sẽ xét địa chỉ cách i là 12, nếu lại bị xung đột thì hàm băm lại lần 2 h2 sẽ xét địa chỉ cách i 22 ,… , quá trình cứ thế cho đ ến khi nào tìm được trống và thêm phần tử vào địa chỉ này. - K hi tìm kiếm một phần tử có khóa key trong bảng băm thì xét phần tử tại địa chỉ i=f(key), nếu chưa tìm thấy thì xét phần tử cách i 12, 22, …, quá trình cứ thế cho đến khi tìm đ ược khóa (trường hợp tìm thấy) hoặc rơi vào địa chỉ trống (trường hợp không tìm thấy). - H àm băm lại lần thứ i được biểu diễn bằng công thức sau: fi(key)=( f(key) + i2 ) % M với f(key) là hàm băm chính của bảng băm. N ếu đã dò đến cuối bảng thì trở về dò lại từ đầu bảng. Bảng băm minh họa có cấu trúc như sau: - Tập khóa K: tập số tự nhiên - Tập địa chỉ M: gồm 10 địa chỉ (M={0, 1, …, 9} - H àm băm f(key) = key % 10. K hai báo cấu trúc bảng băm: #define NULLKEY –1 #define M 101 13
  4. /* M la so nut co tren bang bam,du de chua cac nut nhap vao bang bam,chon M la so nguyen to */ //Khai bao nut cua bang bam struct node { int key; //Khoa cua nut tren bang bam }; //Khai bao bang bam co M nut struct node hashtable[M]; int N; C ài đặt bảng băm dùng phương pháp dò bậc hai: Hàm băm: Giả sử chúng ta chọn hàm băm dạng%: f(key)=key %10. int hashfunc(int key) { return(key% 10); } Phép toán initialize void initialize() { int i; for(i=0; i
  5. Phép toán full: int full() { return(N = = M-1 ?TRUE :FALSE); } Phép toán search: Tìm phần tử có khóa k trên b ảng băm,nếu không tìm thấy hàm này trả về trị M, nếu tìm thấy hàm này trả về địa chỉ tìm thấy. int search(int k) { int i, d; i = hashfuns(k); d = 1; while(hashtable[i].key!=k&&hashtable[i].key !=NULLKEY) { //Bam lai (theo phuong phap bac hai) i = (i+d) % M; d = d+2; } hashtable[i].key =k; N = N +1; return(i); } 2.4.5. Bảng băm với phương pháp băm kép Mô tả: Phương pháp băm kép dùng hai hàm băm bất kì, ví dụ chọn hai hàm băm như sau: h1(key)= key %M. h2(key) =(M-2)-key %(M-2). 15
ADSENSE

CÓ THỂ BẠN MUỐN DOWNLOAD

 

Đồng bộ tài khoản
2=>2