Bài tập Thực toán tìm kiếm có đáp án
29 người thi tuần này 4.6 1.2 K lượt thi 8 câu hỏi
Bạn cần đăng ký gói VIP ( giá chỉ từ 250K ) để làm bài, xem đáp án và lời giải chi tiết không giới hạn.
🔥 Học sinh cũng đã học
Đề thi cuối kì 2 Tin học 7 Kết nối tri thức có đáp án - Đề 7
Đề thi cuối kì 2 Tin học 7 Kết nối tri thức có đáp án - Đề 6
Đề thi cuối kì 2 Tin học 7 Kết nối tri thức có đáp án - Đề 5
Đề thi giữa kì 2 Tin học 7 Kết nối tri thức có đáp án - Đề 7
Đề thi giữa kì 2 Tin học 7 Kết nối tri thức có đáp án - Đề 6
Đề thi giữa kì 2 Tin học 7 Kết nối tri thức có đáp án - Đề 5
Đề thi cuối kì 1 Tin học 7 Kết nối tri thức có đáp án - Đề 7
Đề thi cuối kì 1 Tin học 7 Kết nối tri thức có đáp án - Đề 6
Danh sách câu hỏi:
Lời giải
Em có thể tìm một thẻ bất kì theo yêu cầu trong dãy số trên (Hình 1) bằng cách lặt từng thẻ số.
Lời giải
Đáp án: B
Để tìm kiếm một số trong dãy số bằng thuật toán tìm kiếm tuần tự, ta thực hiện so sánh lần lượt từ số đầu tiên trong dãy số với số cần tìm.
Lời giải
Các em tham khảo hướng dẫn sau:
Chuẩn bị 10 thẻ được đánh thứ từ từ A, B, C, D, E, F, G, H, K, L và sau thẻ đánh số tương ứng 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 xếp sắp theo thứ tự tăng dần.
a) Thẻ số tăng dần: Tìm số 8
|
Dãy thẻ số |
1 |
2 |
3 |
4 |
5 |
6 |
7 |
8 |
9 |
10 |
|
Thứ tự |
A |
B |
C |
D |
E |
F |
G |
H |
K |
L |
Hình 2: Thẻ số tăng dần
b)
Gọi số cần tìm là x = 8.
Bước 1. Lật thẻ ở vị trí E (E = 5).
Bước 2. So sánh số thấy vị trí E khác vị trí cần tìm (8 > 5) nên ta chỉ cần tìm ở nữa sau của dãy thẻ (gồm F, G, H, K, L).
Bước 3. Lật thẻ vị trí H (H = 8).
Bước 4. So sánh số thấy vị trí H bằng với kết quả cần tìm. Kết quả tìm thấy số 8 trong dãy ở vị trí H và kết thúc quá trình tìm kiếm.
c) Thay đổi vai trò
Gọi số cần tìm là x = 10.
Bước 1. Lật thẻ ở vị trí E (E = 5).
Bước 2. So sánh số thấy vị trí E khác vị trí cần tìm (10 > 5) nên ta chỉ cần tìm ở nữa sau của dãy thẻ (gồm F, G, H, K, L).
Bước 3. Lật thẻ vị trí H (H = 8).
Bước 4. So sánh số thấy vị trí H khác vị trí cần tìm (10 > 8). Nên ta chỉ cần tìm ở nữa sau của dãy thẻ (gồm K, L).
Bước 5. Ta lật ngẫu nhiên vị trí K hoặc L.
+ TH1: Lật thẻ vị trí K: So sánh số thấy vị trí K khác vị trí cần tìm (10 > 9). Tiếp theo ta lật thẻ còn lại, so sánh số thấy vị trí L bằng với kết quả cần tìm. Kết quả tìm thấy số 10 trong dãy ở vị trí L và kết thúc quá trình tìm kiếm.
+ TH2: Lật thẻ vị trí L: So sánh số thấy vị trí L bằng với kết quả cần tìm. Kết quả tìm thấy số 10 trong dãy ở vị trí L và kết thúc quá trình tìm kiếm.
Lời giải
Giả sử tháng sinh của em là tháng 3. Em sẽ đi hỏi tháng sinh của các bạn và ghi vào bảng thống kê:
|
Lần lặp |
Tháng sinh của bạn |
Cùng tháng sinh với em |
Đã hết danh sách/ đã hỏi hết các bạn |
|
1 |
4 |
Sai |
Sai |
|
2 |
2 |
Sai |
Sai |
|
3 |
1 |
Sai |
Sai |
|
4 |
5 |
Sai |
Sai |
|
5 |
6 |
Sai |
Sai |
|
6 |
8 |
Sai |
Sai |
|
7 |
12 |
Sai |
Sai |
|
8 |
11 |
Sai |
Sai |
|
9 |
3 |
Đúng |
Sai |
|
Sau lần lặp thứ 9 đã có bạn cùng tháng sinh với em. Kết thúc tìm kiếm. |
|||
Lời giải
a) Biển số xe cần tìm là 25.
|
Lần lặp |
Biển số xe tỉnh |
Cùng biển số xe |
Danh sách tìm kết toàn bộ bảng |
|
1 |
67 |
Sai |
Sai |
|
2 |
72 |
Sai |
Sai |
|
3 |
77 |
Sai |
Sai |
|
4 |
69 |
Sai |
Sai |
|
5 |
27 |
Sai |
Sai |
|
6 |
81 |
Sai |
Sai |
|
7 |
79 |
Sai |
Sai |
|
8 |
25 |
Đúng |
Sai |
|
Sau 8 lần lặp đã tìm được kết quả. Kết thúc tìm kiếm. |
|||
b)
Bước 1. Sắp xếp biển số xe theo thứ tự tăng dần hoặc giảm dần.
Bảng. Biển số xe tăng dần
Bước 2. Lật thẻ số ở giữa của dãy (thẻ thứ 5). So sánh số cần tìm là 25 trên thẻ vừa lật là 67. Do 25 < 67 nên chỉ cần tìm ở nửa đầu của dãy thẻ (gồm 1, 2, 3, 4)
Bước 4. Lật thẻ số ở giữa của dãy (thẻ thứ 2). So sánh số cần tìm là 25 trên thẻ vừa lật là 21. Do 25 > 21 nên số cần tìm ở nửa sau của dãy thẻ (vị trí số 3, 4).
Bước 5. Lật thẻ vị trí số 3. So sánh số cần tìm là 25 trên thẻ vừa lật là 25. Do 25 = 25 nên đưa ra thông báo đã tìm thấy kết quả. Kết thúc quá trình tìm kiếm.
c) Số lần lặp lại ở câu b ít hơn câu a. Vì tìm kiếm nhị phân chia nhỏ mảng tìm kiếm nên số lần lặp ít hơn.
d) Ta có thể dùng thuật toán tìm kiếm nhị phân để tìm ra tỉnh khi biết hai số đầu của biển số xe. Vì khi thực hiện tìm kiếm ta sẽ chia nhỏ mảng số và tìm được số cần tìm.
Lời giải
Bạn cần đăng ký gói VIP ( giá chỉ từ 250K ) để làm bài, xem đáp án và lời giải chi tiết không giới hạn.
Lời giải
Bạn cần đăng ký gói VIP ( giá chỉ từ 250K ) để làm bài, xem đáp án và lời giải chi tiết không giới hạn.
Xem tiếp với tài khoản VIP
Còn 2/8 câu hỏi, đáp án và lời giải chi tiết.
Bạn cần đăng ký gói VIP ( giá chỉ từ 250K ) để làm bài, xem đáp án và lời giải chi tiết không giới hạn.
