Đáp án Tin 11 Khoa học máy tính Kết nối bài 25 Xác định độ phức tạp thời gian thuộc toán

Đáp án bài 25 Xác định độ phức tạp thời gian thuộc toán. Bài giải được trình bày ngắn gọn, chính xác giúp các em học Tin 11 Khoa học máy tính Kết nối tri thức dễ dàng. Từ đó, hiểu bài và vận dụng vào các bài tập khác. Đáp án chuẩn chỉnh, rõ ý, dễ tiếp thu. Kéo xuống dưới để xem chi tiết

BÀI 25 - THỰC HÀNH XÁC ĐỊNH ĐỘ PHỨC TẠP THỜI GIAN THUẬT TOÁN

MỞ ĐẦU

CH 1: Biết cách phân tích, đánh giá độ phức tạp thuật toán là kĩ năng quan trọng của người thiết kế thuật toán và chương trình. Các quy tắc đơn giản tính độ phức tạp thời gian mang lại cho em điều gì khi đánh giá thuật toán?

Đáp án chuẩn:

Đánh giá được mức đơn giản của thuật toán.

LUYỆN TẬP

CH 1: Xác định độ phức tạp của thuật toán sắp xếp nỗi bọt sau:

def BubbleSort(A):

n = len(A}

for i in range(n-1):

 for" j in range(n-1-i):

for A[j] > A[j+1]:

A[j],A{fj+1] = A[3+1]1,A[3]

Đáp án chuẩn:

Độ phức tạp của thuật toán sắp xếp nổi bọt là O(n2). T=O(n)+O(n2)=O(n2)

CH 2: Cho biết hàm sau sẽ trả về giá trị là bao nhiêu? Xác định độ phức tạp thời gian O- lớn của chương trình.

MỞ ĐẦUCH 1: Biết cách phân tích, đánh giá độ phức tạp thuật toán là kĩ năng quan trọng của người thiết kế thuật toán và chương trình. Các quy tắc đơn giản tính độ phức tạp thời gian mang lại cho em điều gì khi đánh giá thuật toán?Đáp án chuẩn:Đánh giá được mức đơn giản của thuật toán.LUYỆN TẬPCH 1: Xác định độ phức tạp của thuật toán sắp xếp nỗi bọt sau:def BubbleSort(A):n = len(A}for i in range(n-1): for  j in range(n-1-i):for A[j] > A[j+1]:A[j],A{fj+1] = A[3+1]1,A[3]Đáp án chuẩn:Độ phức tạp của thuật toán sắp xếp nổi bọt là O(n2). T=O(n)+O(n2)=O(n2)CH 2: Cho biết hàm sau sẽ trả về giá trị là bao nhiêu? Xác định độ phức tạp thời gian O- lớn của chương trình.Đáp án chuẩn:Hàm

Đáp án chuẩn:

Hàm "Mystery(n)" sẽ trả về giá trị là r. Độ phức tạp thời gian của chương trình này là O(n3)

VẬN DỤNG

CH 1: Giả sử rằng mỗi phép tính đơn được thực hiện trong micro giây (1 us = một phần triệu giây). Hãy xác định giá trị lớn nhất của n trong các thuật toán tìm kiếm tuần tự, sắp xếp chèn và sắp xếp chọn nếu thời gian thực thi các thuật toán là 1 giây, 1 phút và 1 giờ?

Đáp án chuẩn:

1. Thuật toán tìm kiếm tuần tự:

  • Độ phức tạp là O(n)

  • nmax với thời gian thực thi là 1 giây: n = 1 giây * (106 us / phép tính) = 106

  • nmax với thời gian thực thi là 1 phút: n = 1 phút * (60 giây / phút) * (106us / phép tính) = 6 * 107

  • nmax với thời gian thực thi là 1 giờ: n = 1 giờ * (60 phút / giờ) * (60 giây / phút) * (106us / phép tính) = 3.6 * 109

2. Thuật toán sắp xếp chèn:

  • Độ phức tạp là O(102

  • nmax với thời gian thực thi là 1 giây: n = sqrt(1 giây * (106us / phép tính)) =103

  • nmax với thời gian thực thi là 1 phút: n = sqrt(1 phút * (60 giây / phút) * (106us / phép tính)) = 6 * 104

  • nmax với thời gian thực thi là 1 giờ: n = sqrt(1 giờ * (60 phút / giờ) * (60 giây / phút) * (106us / phép tính)) = 3.6 * 106

3. Thuật toán sắp xếp chọn:

  • Độ phức tạp là O(n2)

  • Giá trị lớn nhất của n = sqrt(1 giây * (106us / phép tính)) = 1000.

  • Thời gian thực thi là 1 phút: Giá trị lớn nhất của n = sqrt(1 phút * (60 giây / phút) * (106us / phép tính)) = 60000.

  • Thời gian thực thi là 1 giờ: Giá trị lớn nhất của n = sqrt(1 giờ * (60 phút / giờ) * (60 giây / phút) * (106us / phép tính)) = 3.6 * 106

CH 2: Hãy cho biết hàm sau thực hiện công việc gì? Xác định độ phức tạp thời gian của thuật toán.

MỞ ĐẦUCH 1: Biết cách phân tích, đánh giá độ phức tạp thuật toán là kĩ năng quan trọng của người thiết kế thuật toán và chương trình. Các quy tắc đơn giản tính độ phức tạp thời gian mang lại cho em điều gì khi đánh giá thuật toán?Đáp án chuẩn:Đánh giá được mức đơn giản của thuật toán.LUYỆN TẬPCH 1: Xác định độ phức tạp của thuật toán sắp xếp nỗi bọt sau:def BubbleSort(A):n = len(A}for i in range(n-1): for  j in range(n-1-i):for A[j] > A[j+1]:A[j],A{fj+1] = A[3+1]1,A[3]Đáp án chuẩn:Độ phức tạp của thuật toán sắp xếp nổi bọt là O(n2). T=O(n)+O(n2)=O(n2)CH 2: Cho biết hàm sau sẽ trả về giá trị là bao nhiêu? Xác định độ phức tạp thời gian O- lớn của chương trình.Đáp án chuẩn:Hàm

Đáp án chuẩn:

Công việc của hàm là thực hiện sắp xếp. Độ phức tạp của thuật toán là O(n2)

Thêm kiến thức môn học

Bình luận

Giải bài tập những môn khác