
Anonymous
0
0
Lý thuyết Tin học 7 Bài 15 (Kết nối tri thức): Thuật toán tìm kiếm nhị phân
- asked 6 months agoVotes
0Answers
0Views
Lý thuyết Tin học 7 Bài 15: Thuật toán tìm kiếm nhị phân
1. Thuật toán tìm kiếm nhị phân
- Thuật toán tìm kiếm nhị phân:
+ Thực hiện trên danh sách đã được sắp xếp. Bắt đầu từ vị trí ở giữa danh sách.
+ Tại mỗi bước, so sánh giá trị cần tìm với giá trị ở vị trí giữa danh sách, nếu lớn hơn thì tìm ở nửa sau của danh sách, nếu nhỏ hơn thì tìm ở nửa trước của danh sách, nếu bằng thì dừng lại.
+ Chừng nào chưa tìm thấy và chưa hết thì còn tìm tiếp.
- Mô tả bằng ngôn ngữ tự nhiên:
Bước 1. Nếu vùng tìm kiếm không có phần tử nào thì kết luận không tìm thấy và kết thúc.
Bước 2. Xác định vị trí ở giữa của vùng tìm kiếm. Vị trí này chia vùng tìm kiếm thành hai nửa: nửa trước và nửa sau vị trí giữa.
Bước 3. Nếu giá trị cần tìm bằng giá trị ở vị trí giữa thì kết luận và kết thúc.
Bước 4. Nếu giá trị cần tìm nhỏ hơn giá trị của vùng vị trí giữa thì vùng tìm kiếm mới được thu hẹp lại, chỉ còn nửa trước của dãy, ngược lại chỉ còn nửa sau của dãy.
Bước 5. Lặp lại từ Bước 1 đến Bước 4 cho đến khi thấy giá trị cần tìm (Bước 3) hoặc vùng tìm kiếm không còn phần tử nào (Bước 1).
Hình 1. Vùng tìm kiếm
Lưu ý: “nửa trước” và “nửa sau” không gồm phần tử giữa.
- Ví dụ: Các bước để An tìm kiếm khách hàng tên Trúc trong danh sách ở Hình 1 theo thuật toán tìm kiếm nhị phân
Hình 2. Danh sách khách hàng
Bước 1. Xét vị trí ở giữa của dãy đó, vị trí số 5
Bước 2. Xét vị trí ở giữa của nửa sau là vị trí số 7
Bước 3. Xét vị trí ở giữa của nửa sau còn lại của dãy đó là vị trí số 8
Vì sau bước 3, đã tìm thấy khách hàng nên kết thúc thuật toán