Tải bản đầy đủ (.pdf) (6 trang)

vo thuc hanh tin hoc 7 bai 15 thuat toan tim kiem nhi phan ket noi tri

Bạn đang xem bản rút gọn của tài liệu. Xem và tải ngay bản đầy đủ của tài liệu tại đây (203.01 KB, 6 trang )

Bài 15. Thuật toán tìm kiếm nhị phân
Câu hỏi
Câu hỏi 15.1 trang 72 vở thực hành Tin lớp 7: Em hãy viết các bước thực hiện
thuật tốn tìm kiếm nhị phân để tìm khách hàng tên "Hịa" trong danh sách ở Hình
15.1.

Gợi ý: Vị trí giữa của vùng tìm kiếm bằng phần nguyên của (vị trí đầu + vị trí
cuối) /2.

Em hãy điền vào chỗ chấm trong gợi ý ở Bước 1 sau đây các bước sau thực hiện
tương tự.
Trả lời:
Bước 1. Vị trí giữa của vùng tìm kiếm là 5. So sánh “Hịa” và “Mai”. Vì H đứng
trước M trong bảng chữ cái nên vùng tìm kiếm là nửa trước của dãy (từ vị trí 1
đến vị trí 4).
Bước 2. Vị trí giữa của vùng tìm kiếm là 2. So sánh “Hịa” và “Bình”. Vì H đứng
sau B trong bảng chữ cái nên vùng tìm kiếm là nửa sau của dãy (từ vị trí 3 đến vị
trí 4).
Bước 3. Vị trí giữa của vùng tìm kiếm là 3. So sánh ta thấy giá trị ở vị trí giữa
đúng là “Hịa” là giá trị cần tìm. Thuật tốn kết thúc.


Câu hỏi 15.2 trang 73 vở thực hành Tin lớp 7: Em hãy nêu ví dụ trong thực tế
cho thấy mối liên quan giữa sắp xếp và tìm kiếm.
Gợi ý: Sắp xếp và tìm kiếm có mối liên hệ mật thiết với nhau. Khi danh sách được
sắp xếp, việc tìm kiếm sẽ được thực hiện nhanh chóng. Trong thư viện, các cuốn
sách được sắp xếp theo lĩnh vực, trong mỗi lĩnh vực, sách lại được sắp xếp theo
thứ tự theo chữ cái tên của tác giả hoặc tên sách. Việc này giúp cho người thủ thư
dễ dàng tìm thấy cuốn sách mà em muốn mượn. Dựa vào ví dụ này khơng có thể
nêu thêm các ví dụ khác trong thực tế.
Trả lời:


Ví dụ: Việc tra từ điển tiếng anh. Trong từ điển, các từ tiếng anh được sắp xếp
theo một trật tự bảng chữ cái. Việc làm này sẽ thuận lợi cho việc tra từ điển tiếng
anh một cách dễ dàng.
Luyện tập
Luyện tập 15.3 trang 73 vở thực hành Tin lớp 7: Cho danh sách tên các nước
sau đây:
Bolivia, Albania, Scotland, Canada, Vietnam, Iceland, Portugal, Greendland,
Germany
a) Em hãy sắp xếp danh sách tên các nước theo thứ tự trong bảng chữ cái.
b) Em hãy liệt kê các bước tìm kiếm tên nước Iceland trong danh sách đã sắp xếp
theo thuật tốn tìm kiếm nhị phân.
c) Em hãy so sánh số bước thực hiện tìm kiếm ở phần b với số bước thực hiện tìm
kiếm ở Câu 14.3 phần Luyện tập của bài 14.
Gợi ý: Thuật tốn tìm kiếm nhị phân thực hiện trên danh sách đã được sắp xếp.
Do đó trước tiên cần sắp xếp danh sách theo thứ tự bảng chữ cái. Sau đó thực hiện
thuật tốn tìm kiếm nhị phân tên nước Iceland trong danh sách đã sắp xếp.
Trả lời:
a) Sắp xếp danh sách tên các nước theo thứ tự trong bảng chữ cái: Albania,
Bolivia, Canada, Germany, Greendland, Iceland, Portugal, Scotland, Vietnam
b) Các bước tìm kiếm tên nước Iceland trong danh sách đã sắp xếp theo thuật tốn
tìm kiếm nhị phân:


Bước 1: Vị trí ở giữa của vùng tìm kiếm là 5 _Greenland. So sánh “Iceland” và
“Greenland”. Vì I đứng sau G trong bảng chữ cái nên vùng tìm kiếm là nửa
sau của dãy.
Bước 2: Vị trí ở giữa của vùng tìm kiếm là 7 _Portugal. So sánh “Iceland” và
“Portugal”. Vì I đứng trước P trong bảng chữ cái nên vùng tìm kiếm là nửa
đầu của dãy.
Bước 3: Vì nửa trước của dãy chỉ cịn một tên, đó là vị trí số 6_ Iceland. So sánh

thấy “Iceland” trùng với “Iceland”, tìm thấy tên nước cần tìm nên thuật tốn
dừng lại.
c) Số bước thực hiện tìm kiếm ở Câu 14.3 của Bài 14 là: 6 bước.
Số bước thực hiện tìm kiếm ở câu b là: 3 bước
So sánh: Số bước thực hiện tìm kiếm ở phần b ít hơn so với số bước thực hiện tìm
kiếm ở Câu 14.3 phần Luyện tập của bài 14.
Luyện tập 15.4 trang 74 vở thực hành Tin lớp 7: Em hãy cho ví dụ một bài
tốn tìm kiếm trong thực tế mà có thể thực hiện bằng thuật tốn tìm kiếm nhị
phân? Hãy thực hiện thuật tốn tìm kiếm nhị phân để giải quyết bài tốn đó.
Gợi ý: Thuật tốn tìm kiếm nhị phân thực hiện tìm kiếm trên danh sách đã được
sắp xếp. Một số ví dụ về danh sách như sau: danh sách học sinh trong lớp, danh
mục sách trong thư viện, danh mục hàng hóa, danh mục thiết bị,… Trước tiên em
lập danh sách và sắp xếp danh sách. Sau đó xác định giá trị cần tìm. Cuối cùng
thực hiện thuật tốn tìm kiếm nhị phân để tìm giá trị trong danh sách đã được sắp
xếp.
Trả lời:
Ví dụ một bài tốn tìm kiếm trong thực tế: Giáo viên muốn tìm tên bạn Chung
trong danh sách lớp sau:


Các bước thực hiện thuật tốn tìm kiếm nhị phân cho bài tốn trên:
Bước 1: Xét vị trí ở giữa dãy, đó là vị trí số 5

Bước 2: Xét vị trí ở giữa của nửa đầu của dãy là vị trí số 3


Vì sau bước 2 đã tìm thấy tên học sinh nên thuật toán kết thúc.
Vận dụng
Vận dụng 15.5 trang 75 vở thực hành Tin lớp 7: Em tìm một từ tiếng Anh trong
quyển từ điển theo cách nào? Tại sao em lại dùng cách đó?

Gợi ý: Các từ trong từ điển thường được sắp xếp theo bảng chữ cái với danh sách
đã được sắp xếp em nên tìm kiếm bằng thuật tốn tìm kiếm nào để hiệu quả và
nhanh chóng?
Trả lời:
Em tìm một từ tiếng Anh trong quyển từ điển bằng cách chia đổi quyển từ điển,
tìm một từ bất kì ở giữa quyển từ điển và so sánh với từ cần tìm. Nếu tìm thấy từ
đó thì sẽ kết thúc việc tìm kiếm. Nếu chưa em lại tiếp tục chia quyển từ điển theo
nửa thích hợp, đến khi nào tìm được từ cần tìm thì kết thúc. Em dùng cách này vì
nhanh chóng và thuận tiện hơn là tìm kiếm từng từ trong bảng chữ cái.
Bổ sung
Bổ sung 15.6 trang 75 vở thực hành Tin lớp 7: Điều kiện lặp của thuật tốn tìm
kiếm nhị phân là gì?
A. Chưa tìm thấy phần tử cần tìm.
B. Chưa hết danh sách.
C. Chưa tìm thấy phần tử cần tìm hoặc chưa hết danh sách.
D. Chưa tìm thấy phần tử cần tìm và chưa hết danh sách.
Gợi ý: Thuật tốn tìm kiếm nhị phân chừng nào chưa tìm thấy và chưa tìm hết thì
cịn tiền tiếp.
Trả lời:
Đáp án đúng là: D
Thuật tốn tìm kiếm nhị phân chừng nào chưa tìm thấy và chưa tìm hết thì cịn
tiền tiếp.
Bổ sung 15.7 trang 75 vở thực hành Tin lớp 7: Thuật tốn tìm kiếm nhị phân
cần bao nhiêu bước để tìm thấy Thailand trong danh sách tên các nước sau:
Brunei, Campodia, Laos, Myanmar, Singpore, Thailand, Vietnam
A. 1

B. 2

C. 3


D. 4


Gợi ý: Em thực hiện các bước tìm kiếm theo thuật tốn tìm kiếm nhị phân để tìm
ra câu trả lời.
Trả lời:
Đáp án đúng là: B
Bước 1: Vị trí giữa của vùng tìm kiếm là Myanmar, So sánh Thailand và
Myanmar, → vùng tìm kiếm là nửa sau của dãy.
Bước 2: Vị trí giữa của vùng tìm kiếm là Thailand, so sánh Thailand và
Thailand → trùng nhau nên kết thúc việc tìm kiếm.
Bổ sung 15.8 trang 75 vở thực hành Tin lớp 7: Thuật tốn tìm kiếm nhị phân
cần thực hiện bao nhiêu bước để thơng báo khơng tìm thấy số 10 trong danh sách
[2, 5, 8, 11, 14, 17] ?
A. 2

B. 3

C. 4

D. 5

Gợi ý: Thơng báo khơng tìm thấy số 10 khi thuật tốn đã tìm hết danh sách. Em
thực hiện các bước tìm kiếm theo thuật tốn tìm kiếm nhị phân để tìm ra câu trả
lời.
Trả lời:
Đáp án đúng là: B
Bước 1: Vị trí giữa của vùng tìm kiếm là 8, So sánh 10 và 8 → vùng tìm kiếm là
nửa sau của dãy.

Bước 2: vị trí giữa của vùng tìm kiếm là 14, so sánh 14 và 10 → vùng tìm kiếm
là nửa đầu của dãy.
Bước 3. Trong dãy còn số 11, so sánh 11 khác 10 → Khơng tìm thấy số 10 → Kết
thúc.



×