Tìm Kiếm Bằng Bảng Băm
Có thể bạn quan tâm
- Cấu trúc dữ liệu và giải thuật
- Giới thiệu
- Cấu trúc dữ liệu là gì ?
- Cài đặt môi trường
- Một số khái niệm về Giải thuật
- Giải thuật là gì ?
- Giải thuật tiệm cận - Asymptotic Algorithms
- Giải thuật tham lam - Greedy Algorithms
- Giải thuật chia để trị - Divide and Conquer
- Giải thuật qui hoạch động - Dynamic Programming
- Giải thuật định lý thợ - Master Theorem
- Cấu trúc dữ liệu mảng (Array)
- Cấu trúc dữ liệu mảng (Array)
- Danh sách liên kết - Linked Lists
- Danh sách liên kết - Linked List
- Danh sách liên kết đôi - Doubly Linked List
- Danh sách liên kết vòng - Circular Linked List
- Ngăn xếp & Hàng đợi
- Cấu trúc dữ liệu ngăn xếp - Stack
- Cấu trúc dữ liệu hàng đợi - Queue
- Một số Giải thuật tìm kiếm
- Tìm kiếm tuyến tính - Linear Search
- Tìm kiếm nhị phân - Binary Search
- Tìm kiếm nội suy - Interpolation Search
- Cấu trúc dữ liệu Hash Table
- Một số Giải thuật sắp xếp
- Giải thuật sắp xếp
- Sắp xếp nổi bọt - Bubble Sort
- Sắp xếp chèn - Insertion Sort
- Sắp xếp chọn - Selection Sort
- Sắp xếp trộn - Merge Sort
- Giải thuật Shell Sort
- Sắp xếp nhanh - Quick Sort
- Quay lui - Back Tracking
- Cấu trúc dữ liệu đồ thị (Graph)
- Cấu trúc dữ liệu đồ thị
- Tìm kiếm theo chiều sâu - Depth First Traversal
- Tìm kiếm theo chiều rộng - Breadth First Traversal
- Cấu trúc dữ liệu cây
- Cấu trúc dữ liệu cây
- Duyệt cây - Tree Traversal
- Cây tìm kiếm nhị phân - Binary Search Tree
- Cây AVL - AVL Tree
- Cây Slay - splay Tree
- Giải thuật Cây khung - Spanning Tree
- Cấu trúc dữ liệu Heap
- Đệ qui (Recursion)
- Khái niệm cơ bản về Đệ qui
- Bài toán Tháp Hà Nội - Tower of Hanoi
- Dãy Fibonacci
- Tài liệu tham khảo
- Học lập trình C
- Học lập trình C++
- Học lập trình Java
Cấu trúc dữ liệu Bảng Băm là một cấu trúc dữ liệu lưu giữ dữ liệu theo cách thức liên hợp. Trong Bảng Băm, dữ liệu được lưu giữ trong định dạng mảng, trong đó các giá trị dữ liệu có giá trị chỉ mục riêng. Việc truy cập dữ liệu trở nên nhanh hơn nếu chúng ta biết chỉ mục của dữ liệu cần tìm.
Do đó, với loại cấu trúc dữ liệu Bảng Băm này thì các hoạt động chèn và hoạt động tìm kiếm sẽ diễn ra rất nhanh, bất chấp kích cỡ của dữ liệu là bao nhiêu. Bảng Băm sử dụng mảng như là một kho lưu giữ trung gian và sử dụng kỹ thuật Hash để tạo chỉ mục tại nơi phần tử được chèn vào.
Chương trình minh họa Bảng Băm trong C
#include <stdio.h> #include <string.h> #include <stdlib.h> #include <stdbool.h> #define SIZE 20 struct DataItem { int data; int key; }; struct DataItem* hashArray[SIZE]; struct DataItem* dummyItem; struct DataItem* item; int hashCode(int key){ return key % SIZE; } struct DataItem *search(int key){ //lay gia tri hash int hashIndex = hashCode(key); //di chuyen trong mang cho toi khi gap mot o trong (empty cell) while(hashArray[hashIndex] != NULL){ if(hashArray[hashIndex]->key == key) return hashArray[hashIndex]; //di chuyen toi o tiep theo ++hashIndex; //bao quanh hash table hashIndex %= SIZE; } return NULL; } void insert(int key,int data){ struct DataItem *item = (struct DataItem*) malloc(sizeof(struct DataItem)); item->data = data; item->key = key; //lay gia tri hash int hashIndex = hashCode(key); //di chuyen trong mang cho toi khi gap mot o trong (empty cell) hoac o bi xoa while(hashArray[hashIndex] != NULL && hashArray[hashIndex]->key != -1){ //di chuyen toi o tiep theo ++hashIndex; //bao quanh hash table hashIndex %= SIZE; } hashArray[hashIndex] = item; } struct DataItem* deleteItem(struct DataItem* item){ int key = item->key; //lay gia tri hash int hashIndex = hashCode(key); //di chuyen trong mang cho toi khi gap mot o trong (empty cell) while(hashArray[hashIndex] != NULL){ if(hashArray[hashIndex]->key == key){ struct DataItem* temp = hashArray[hashIndex]; //gan mot phan tu gia tai vi tri bi xoa hashArray[hashIndex] = dummyItem; return temp; } //di chuyen toi o tiep theo ++hashIndex; //bao quanh hash table hashIndex %= SIZE; } return NULL; } void display(){ int i = 0; for(i = 0; i<SIZE; i++) { if(hashArray[i] != NULL) printf(" (%d,%d)",hashArray[i]->key,hashArray[i]->data); else printf(" ~~ "); } printf("\n"); } int main(){ dummyItem = (struct DataItem*) malloc(sizeof(struct DataItem)); dummyItem->data = -1; dummyItem->key = -1; insert(1, 20); insert(2, 70); insert(42, 80); insert(4, 25); insert(12, 44); insert(14, 32); insert(17, 11); insert(13, 78); insert(37, 97); display(); item = search(37); if(item != NULL){ printf("Tim thay phan tu: %d\n", item->data); }else { printf("Khong tim thay phan tu\n"); } deleteItem(item); item = search(37); if(item != NULL){ printf("Tim thay phan tu: %d\n", item->data); }else { printf("Khong tim thay phan tu\n"); } }Kết quả
Biên dịch và chạy chương trình C trên sẽ cho kết quả:
Đã có app VietJack trên điện thoại, giải bài tập SGK, SBT Soạn văn, Văn mẫu, Thi online, Bài giảng....miễn phí. Tải ngay ứng dụng trên Android và iOS. Theo dõi chúng tôi miễn phí trên mạng xã hội facebook và youtube:
Follow fanpage của team https://www.facebook.com/vietjackteam/ hoặc facebook cá nhân Nguyễn Thanh Tuyền https://www.facebook.com/tuyen.vietjack để tiếp tục theo dõi các loạt bài mới nhất về Java,C,C++,Javascript,HTML,Python,Database,Mobile.... mới nhất của chúng tôi.
Bài học Cấu trúc dữ liệu và giải thuật phổ biến tại vietjack.com:
- Giải thuật tiệm cận - Asymptotic Algorithms
- Cấu trúc dữ liệu mảng (Array)
- Danh sách liên kết - Linked List
- Cấu trúc dữ liệu ngăn xếp - Stack
- Cấu trúc dữ liệu hàng đợi - Queue
- Tìm kiếm tuyến tính - Linear Search
- Tìm kiếm nhị phân - Binary Search
- Sắp xếp nổi bọt - Bubble Sort
- Sắp xếp chèn - Insertion Sort
160 bài học ngữ pháp tiếng Anh hay nhất
155 bài học Java tiếng Việt hay nhất
100 bài học Android tiếng Việt hay nhất
247 bài học CSS tiếng Việt hay nhất
197 thẻ HTML cơ bản
297 bài học PHP
101 bài học C++ hay nhất
97 bài tập C++ có giải hay nhất
208 bài học Javascript có giải hay nhất
Học cùng VietJack
Từ khóa » Băm Trong C++
-
Bảng Băm Trong C++ | TopDev
-
Bảng Băm(Hash Table) | Cài đặt Bảng Băm Và Kỹ Thuật Xử Lý Va Chạm
-
Bảng Băm (Hash Table) - VNOI
-
Chi Tiết Bài Học Bảng Băm (Hash Table), Bảng Băm Trong C++
-
Chi Tiết Bài Học Bảng Băm - Hash Table - Vimentor
-
Bài 3 BẢNG BĂM (HASH TABLE) - Cửu Dương Thần Công . Com
-
Bảng Băm Trong Cấu Trúc Dữ Liệu
-
Top 13 Hàm Băm C++
-
Bài Giảng Cấu Trúc Dữ Liệu Và Giải Thuật Trong C++ - Bài: Bảng Băm
-
Cấu Trúc Dữ Liệu & Giải Thuật [14]: #HashTable | Bảng Băm - YouTube
-
Cấu Trúc Dữ Liệu Hash Table
-
CTDL>: 12.Bảng Băm - YouTube
-
Hash Table - Ninja IT