Giải thuật tìm kiếm nhị phân (Binary Search)
Giải thuật tìm kiếm nhị phân (Binary Search) là gì?
Binany Search (Tìm kiếm nhị phân) là một giải thuật tìm kiếm nhanh với độ phức tạp thời gian chạy là Ο(log n). Giải thuật tìm kiếm nhị phân làm việc dựa trên nguyên tắc chia để trị (Divide and Conquer). Để giải thuật này có thể làm việc một cách chính xác thì tập dữ liệu nên ở trong dạng đã được sắp xếp.
Binary Search tìm kiếm một phần tử cụ thể bằng cách so sánh phần tử tại vị trí giữa nhất của tập dữ liệu. Nếu tìm thấy kết nối thì chỉ mục của phần tử được trả về. Nếu phần tử cần tìm là lớn hơn giá trị phần tử giữa thì phần tử cần tìm được tìm trong mảng con nằm ở bên phải phần tử giữa; nếu không thì sẽ tìm ở trong mảng con nằm ở bên trái phần tử giữa. Tiến trình sẽ tiếp tục như vậy trên mảng con cho tới khi tìm hết mọi phần tử trên mảng con này.
Cách Binary Search làm việc
Để Binary Search làm việc thì mảng phải cần được sắp xếp. Để tiện cho việc theo dõi, mình sẽ cung cấp thêm các hình minh họa tương ứng với mỗi bước.
Giả sử chúng ta cần tìm vị trí của giá trị 31 trong một mảng bao gồm các giá trị như hình dưới đây bởi sử dụng Binary Search:

Đầu tiên, chúng ta chia mảng thành hai nửa theo phép toán sau:
chỉ-mục-giữa = ban-đầu + (cuối + ban-đầu)/ 2
Với ví dụ trên là 0 + (9 – 0)/ 2 = 4 (giá trị là 4.5). Do đó 4 là chỉ mục giữa của mảng.

Bây giờ chúng ta so sánh giá trị phần tử giữa với phần tử cần tìm. Giá trị phần tử giữa là 27 và phần tử cần tìm là 31, do đó là không kết nối. Bởi vì giá trị cần tìm là lớn hơn nên phần tử cần tìm sẽ nằm ở mảng con bên phải phần tử giữa.

Chúng ta thay đổi giá trị ban-đầu thành chỉ-mục-giữa + 1 và lại tiếp tục tìm kiếm giá trị chỉ-mục-giữa.
ban-đầu = chỉ-mục-giữa + 1
chỉ-mục-giữa = ban-đầu + (cuối + ban-đầu)/ 2
Bây giờ chỉ mục giữa của chúng ta là 7. Chúng ta so sánh giá trị tại chỉ mục này với giá trị cần tìm.

Giá trị tại chỉ mục 7 là không kết nối, và ngoài ra giá trị cần tìm là nhỏ hơn giá trị tại chỉ mục 7 do đó chúng ta cần tìm trong mảng con bên trái của chỉ mục giữa này.

Tiếp tục tìm chỉ-mục-giữa lần nữa. Lần này nó có giá trị là 5.

So sánh giá trị tại chỉ mục 5 với giá trị cần tìm và thấy rằng nó kết nối.

Do đó chúng ta kết luận rằng giá trị cần tìm 31 được lưu giữ tại vị trí chỉ mục 5.
Binary Search chia đôi lượng phần tử cần tìm và do đó giảm số lượng phép so sánh cần thực hiện nên giải thuật tìm kiếm này được thực hiện khá nhanh.
Giải thuật mẫu cho Binary Search
Dưới đây là code mẫu cho giải thuật tìm kiếm nhị phân:
Giải thuật tìm kiếm nhị phân (Binary Search)
A ← một mảng đã được sắp xếp
n ← kích cỡ mảng
x ← giá trị để tìm kiếm trong mảng
gán lowerBound = 1
gán upperBound = n
while x not found
if upperBound < lowerBound
EXIT: x không tồn tại.
gán midPoint = lowerBound + ( upperBound - lowerBound ) / 2
if A[midPoint] < x
gán lowerBound = midPoint + 1
if A[midPoint] > x
gán upperBound = midPoint - 1
if A[midPoint] = x
EXIT: x được tìm thấy tại midPoint
kết thúc while
kết thúc giải thuật
Theo Tutorialspoint
Bài trước: Giải thuật tìm kiếm tuyến tính (Linear Search)
Bài tiếp: Giải thuật Tìm kiếm nội suy (Interpolation Search)
Bạn nên đọc
-
Chuyển từ cơ số 16 sang cơ số 2
-
Chuyển từ cơ số 2 sang cơ số 16
-
Công thức tính Diện tích hình vuông, tính Chu vi hình vuông
-
Công thức tính chu vi hình tam giác
-
Công thức tính thể tích khối tròn xoay và ví dụ minh họa
-
Bí mật thú vị ẩn giấu bên trong dòng mã nhị phân trên tờ 50 bảng Anh in hình Alan Turing
-
Công thức tính thể tích hình chóp, chu vi hình chóp
-
Cách tính chu vi hình thang: thường, vuông, cân
-
Công thức tính diện tích hình chóp
Theo Nghị định 147/2024/ND-CP, bạn cần xác thực tài khoản trước khi sử dụng tính năng này. Chúng tôi sẽ gửi mã xác thực qua SMS hoặc Zalo tới số điện thoại mà bạn nhập dưới đây:
-
Code NgầuThích · Phản hồi · 1 · 17/08/20
Cũ vẫn chất
-

Sửa lỗi Fatal Error Wuthering Waves
Hôm qua -

Luyện tập gõ 10 ngón giúp tăng tốc đánh máy
Hôm qua 39 -

Code Vương Giả Vinh Diệu, code Honor of Kings mới nhất
Hôm qua -

Tải full bộ hình nền iOS 18 đầy đủ với độ phân giải cao
Hôm qua -

Cách đăng ký cấp lại thẻ CCCD gắn chip online mẫu mới
Hôm qua -

Tại sao giao diện Windows lại ngày càng rời rạc?
Hôm qua -

Code Lăng Vân Chi Kiếm mới nhất và cách nhập code
Hôm qua -

Cách bật tùy chọn nhà phát triển và tắt nó trên Android
Hôm qua -

Khối D01 thi môn nào, học ngành nào?
Hôm qua -

Mua laptop Windows hiện khó hơn bao giờ hết
Hôm qua
Học IT
Lập trình
Microsoft Word 2013
Microsoft Word 2007
Microsoft Excel 2019
Microsoft Excel 2016
Microsoft PowerPoint 2019
Google Sheets
Lập trình Scratch
Bootstrap
Hướng dẫn
Ô tô, Xe máy