Bài 8: Thực hành thiết thuật toán tìm kiếm theo kĩ thuật chia để trị - Chuyên đề Tin học 11 Kết nối tri thứcCho một dãy số A bất kì. Để xác định một số C cho trước xuất hiện trong dãy A bao nhiều lần thì làm thế nào?♏Tổng hợp đề thi học kì 2 lớp 11 tất cả các môn - Kết nối tri thức Toán - Văn - Anh - Lí - Hóa - SinhQuảng cáo
Lựa chọn câu để xem lời giải nhanh hơn
Câu 1 Trả lời câu hỏi khởi động trang 37 Chuyên đề Tin học 11 Kết nối tri thức Lời giải chi tiết: Bài tập này có thể dễ dàng giải bằng phương pháp tìm kiếm tuần tự đã biết. Gọi count là số lần xuất hiện của C trong dãy. Thực hiện tìm kiếm tuần tự với C, mỗi lần tìm thấy C, tăng biến count lên 1.Luyện tập Trả lời câu hỏi Luyện tập trang 39 Chuyên đề Tin học 11 Kết nối tri thức Lời giải chi tiết: - Chương trình trả về ba giá trị start, end và count, tương ứng với chỉ số đầu tiên, chỉ số cuối cùng và số lượng phần tử của vùng có giá trị bằng C trong dãy A. - Trong trường hợp không tìm thấy C trong dãy A, chương trình trả về -1, -1, 0. - Nếu giá trị tại vị trí mid bằng C, ta sử dụng hai biến start và end để tìm ra chỉ số đầu tiên và cuối cùng của vùng có giá trị bằng C. Sau đó, ta trả về giá trị start + 1, end - 1 và end - start - 1. - Nếu giá trị tại vị trí mid nhỏ hơn C, ta tiếp tục tìm kiếm phần tử có giá trị bằng C ở nửa bên phải của dãy A. - Nếu giá trị tại vị trí mid lớn hơn C, ta tiếp tục tìm kiếm phần tử có giá trị bằng C ở nửa bên trái của dãy A.Vận dụng Câu 1 Trả lời câu hỏi Vận dụng 1 trang 39 Chuyên đề Tin học 11 Kết nối tri thức Lời giải chi tiết: Để tìm số lần xuất hiện của K trong một dãy số chưa được sắp xếp bằng phương pháp chia để trị, ta có thể sử dụng đệ quy và chia dãy số ban đầu thành hai phần. Tiếp tục chia đến khi dãy số chỉ còn một phần tử hoặc không có phần tử nào.Với đầu vào là một dãy số A và một số K, hàm countNum sẽ trả về số lần xuất hiện của K trong dãy số A. Ví dụ: Vận dụng Câu 2 Trả lời câu hỏi Vận dụng 2 trang 39 Chuyên đề Tin học 11 Kết nối tri thức Lời giải chi tiết: Để tìm vị trí thứ i trong dãy số sao cho phần tử thứ i có giá trị bằng i, ta có thể sử dụng phương pháp chia để trị như sau: 1. Tìm giá trị trung bình của left và right: mid = (left + right) // 2 2. Nếu giá trị tại vị trí mid bằng mid, tức là A[mid] == mid, thì trả về mid 3. Nếu giá trị tại vị trí mid lớn hơn mid, tức là A[mid] > mid, thì tiếp tục tìm vị trí thích hợp trong đoạn từ left đến mid-1 4. Nếu giá trị tại vị trí mid nhỏ hơn mid, tức là A[mid] < mid, thì tiếp tục tìm vị trí thích hợp trong đoạn từ mid+1 đến right 5. Nếu không tìm được vị trí thích hợp nào, tức là left > right, thì trả về -1Vận dụng Câu 3 Trả lời câu hỏi Vận dụng 3 trang 39 Chuyên đề Tin học 11 Kết nối tri thức Lời giải chi tiết: Để thiết lập hai hàm firstInd và lastInd bằng kĩ thuật chia để trị, ta có thể áp dụng phương pháp tương tự như khi tìm kiếm số lần xuất hiện của một phần tử trong dãy số bằng kĩ thuật chia để trị. Cụ thể, ta sẽ chia dãy số thành hai nửa và tìm kiếm đệ quy trên từng nửa đó.
Quảng cáo
Tham Gia Group Dành Cho Lớp 11 Chia Sẻ, Trao Đổi Tài Liệu Miễn Phí |