Hướng dẫn map c++ - bản đồ c ++
Trong quá trình học tập và tìm hiểu, có thể các bạn rất quen thuộc và hay sử dụng các phép toán trên mảng, xâu kí tự. Trong bài viết này, mình sẽ giới thiệu với bạn 1 cấu trúc dữ liệu khá mạnh, giúp giải quyết nhiều bài toán với tốc độ cao và cách cài đặt đơn giản. Cấu trúc dữ liệu này mang tên Map (trong C# hay Python thì gọi là Dictionary). Map là gì?Trong 1 số ngôn ngữ lập trình, Map được gọi là Dictionary (như Python hay C#). Trong khuôn khổ bài viết này, mình dùng từ map do thông thạo với C++ và Java. Các cấu trúc dữ liệu như mảng hay xâu kí tự, khi truy xuất dữ liệu bạn sẽ sử dụng một tham số gọi là chỉ số, ví dụ như arr[1], str[2], … Đối với cấu trúc dữ liệu map, để truy xuất dữ liệu bạn sẽ sử dụng một tham số gọi là key Cấu trúc dữ liệu kiểu map là một cấu trúc dữ liệu ánh xạ giữa cái gọi là khoá (key) sang giá trị của khoá đó (gọi là value) Trong cấu trúc dữ liệu này, mỗi một key sẽ nhận một giá trị khác nhau. Ứng dụngỨng dụng của map có rất nhiều. Mình đưa ra 1 số bài toán cơ bản nhé:
Với các bài toán này, bạn có thể sử dụng 2 mảng dữ liệu có cùng độ dài. Một mảng bạn lưu danh sách key, một mảng bạn lưu danh sách các value tương ứng với key đó (cùng chỉ số truy cập mảng). Khi bạn cần tìm value của một key nào đó, bạn duyệt mảng key, tìm chỉ số của phần tử trong mảng có giá trị bằng key cần tìm rồi trả ra giá trị tương ứng ở mảng value. Mã giả của đoạn code này như sau:
Với đoạn mã như trên, độ phức tạp thuật toán sẽ là O(N) (do bạn phải duyệt cả mảng keysArray để tìm cái key bạn muốn). Để tăng tốc độ cho đoạn mã này, bạn có thể cải tiến hàm tìm kiếm theo phương pháp tìm kiếm nhị phân (với điều kiện mảng keysArray đã được sắp xếp). Tất nhiên cách làm này sẽ tốn công cài đặt hơn rất nhiều lần so với việc bạn sử dụng map (hay dictionary) thông qua dòng lệnh duy nhất sau:
Không chỉ là dễ cài đặt và sử dụng, việc sử dụng map còn đáp ứng tốc độ chạy chương trình khá cao (có chút khác biệt giữa 1 vài cách cài đặt map của các ngôn ngữ hoặc thư viện, nhưng chắc chắn là ngon hơn mình tự cài rồi :D) Các loại map và đặc điểm:Nhìn chung có 2 loại map, dựa vào cách cài đặt của map. Một loại là map được cài đặt dựa trên cây đỏ đen (red-black tree), một loại là map được cài đặt dựa trên bảng băm (hashtable) Với C++, map là loại map được cài đặt dựa trên cây đỏ đen, còn unordered_map là loại map được cài đặt dựa trên nguyên lý Hash. Với Java, TreeMap là loại map được cài đặt bởi cây, còn HashMap là loại map đc cài đặt bởi bảng băm (hash table)
Map được cài đặt dựa trên nguyên lý Hashing – băm. Để hiểu về Hashing, chúng ta cần nắm được 3 khái niệm: Hash function, hash value và bucket. Hashing – băm. Để hiểu về Hashing, chúng ta cần nắm được 3 khái niệm: Hash function, hash value và bucket. Hash function, hay còn gọi là hàm băm, là một hàm mà khi ta lấy đầu vào là một giá trị bất kỳ thì ở đầu ra, hash fuction sẽ cho ta một dãy code – được gọi là hash value. Mỗi đầu vào chỉ có duy nhất một hash value., hay còn gọi là hàm băm, là một hàm mà khi ta lấy đầu vào là một giá trị bất kỳ thì ở đầu ra, hash fuction sẽ cho ta một dãy code – được gọi là hash value. Mỗi đầu vào chỉ có duy nhất một hash value. Bucket là nơi mà chúng ta lưu trữ các cặp key-value. Độ phức tạp thuật toán phép thêm và lấy dữ liệu là O(1). Bạn có thể tìm hiểu và nghiên cứu sự khác nhau giữa 2 loại map này ở 1 số link như: là nơi mà chúng ta lưu trữ các cặp key-value. Độ phức tạp thuật toán phép thêm và lấy dữ liệu là O(1). Bạn có thể tìm hiểu và nghiên cứu sự khác nhau giữa 2 loại map này ở 1 số link như: https://www.geeksforgeeks.org/map-vs-unordered_map-c/ hay https://stackoverflow.com/questions/2444359/what-is-the-difference-between-a-hashmap-and-a-treemap Cách sử dụng:Đa phần map có một số phương thức cơ bản và cách sử dụng tương tự nhau ở 1 số ngôn ngữ:
Bài tập ứng dụng:Hãy thử dùng map để giải quyết các bài tập thuật toán ở trong này https://codelearn.io/learning/detail/thuat-toan-can-ban hoặc https://codelearn.io/learning/detail/thu-vien-chuan-cpp bạn nhé. bạn nhé. |