Bài toán sắp xếp: Cho trước một dãy số A, viết chương trình sắp xếp dãy số này

Giải sách bài tập Tin học 10 Bài 31: Thực hành viết chương trình đơn giản

Câu 31.2 trang 63 SBT Tin học 10: Bài toán sắp xếp: Cho trước một dãy số A, viết chương trình sắp xếp dãy số này theo thứ tự tăng dần.

Giả sử chúng ta sẽ áp dụng thuật toán sắp xếp chèn để cài đặt cho chương trình này. Ý tưởng của thuật toán này như sau: Sẽ duyệt từng phần tử của dãy A, tính từ vị trí thứ 2 trở đi. Với mỗi phần tử (giả sử A[k]), sẽ tìm cách chèn phần tử này vào đúng vị trí của dãy con phía trước A[0], [1], ..., A[k-1] sao cho dãy con này được sắp xếp đúng. Sau khi duyệt xong các phần tử của dãy thì dãy gốc đã được sắp xếp xong.

Với mỗi phần tử A[k], việc chèn vào vị trí đúng trong dãy con phía trước được thực hiện bằng một vòng lặp như sau:

j = k – 1

while j > 0 and A[j] > A[j+1]:

 A[j], A[j+1] = A[j+1],A[j]

 j = j – 1

Để tìm lỗi chương trình trên chúng ta áp dụng công cụ printine, in các giá trị trung gian. Với mỗi vòng lặp chính (vòng lặp for k in range(1,n)), chúng ta sẽ in ra các giá trị sau: k, A[k] và kết quả dãy A.

Chương trình được viết như sau, sau khi bổ sung các lệnh in phần tử trung gian.

dayA = [5,1,8,4,2]                  # Dãy gốc cần sắp xếp

def sap_xep (A):

 n = len(A)

 for k in range(1,n):

  print("vòng" ,k, "số đang xét:", A[k], end = " ")

  j = k - 1

  while j > 0 and A[j] > A[j+1]:

   A[j], A[j+1] = A[j+1], A[j]

   j = j - 1

  print(A)

print("Dãy gốc:",dayA)

A = dayA. copy()

sap_xep (A)

print("Dãy đích:",A) 

Em hãy viết lại chương trình trên và tiến hành kiểm thử xem chương trình có lỗi không? Nếu có thì tìm ra lỗi và sửa lại cho chương trình chạy đúng.

Quảng cáo

Lời giải:

Các em tự viết lại chương trình trên:

Bài toán sắp xếp: Cho trước một dãy số A, viết chương trình sắp xếp dãy số này

Kết quả chạy chương trình có thể như sau:

Bài toán sắp xếp: Cho trước một dãy số A, viết chương trình sắp xếp dãy số này

Nhận xét: tại mỗi vòng lặp, các giá trị A[k] cũng đã được di chuyển để được chèn vào một vị trí trong dãy con A[0], A[1], ..., A[k-1], tuy nhiên vị trí A[0] không bị thay đổi. Từ đó chúng ta tìm ra lỗi của chương trình tại vị trí lệnh while:

while j > 0 and A[j] > A[j+1]:

Cần sửa lại như sau:

while j >= 0 and A[j] > A[j+1]:

Chương trình đã tìm ra lỗi nhờ công cụ kiểm thử printine. Chương trình chính thức sau khi sửa như sau.

sap_xep.py

dayA = [5,1,8,4,2]                  # Dãy gốc cần sắp xếp

def sap_xep(A):

 n = len(A)

 for k in range (1,n):

  j = k – 1

  while j >= 0 and A[j] > A[j+1]:

   A[j], A[j+1] = A[j+1], A[j]

   j = j – 1

A = dayA. copy()

sap_xep (A)

print("Dãy đích:", A)

Quảng cáo


Xem thêm các bài giải sách bài tập Tin học lớp 10 Kết nối tri thức hay, ngắn gọn khác:

Tủ sách VIETJACK shopee lớp 10-11 cho học sinh và giáo viên (cả 3 bộ sách):

Săn shopee giá ưu đãi :

ĐỀ THI, GIÁO ÁN, SÁCH LUYỆN THI DÀNH CHO GIÁO VIÊN VÀ PHỤ HUYNH LỚP 10

Bộ giáo án, bài giảng powerpoint, đề thi, sách dành cho giáo viên và gia sư dành cho phụ huynh tại https://tailieugiaovien.com.vn/ . Hỗ trợ zalo VietJack Official

Tổng đài hỗ trợ đăng ký : 084 283 45 85

Đã có app VietJack trên điện thoại, giải bài tập SGK, SBT Soạn văn, Văn mẫu, Thi online, Bài giảng....miễn phí. Tải ngay ứng dụng trên Android và iOS.

Theo dõi chúng tôi miễn phí trên mạng xã hội facebook và youtube:

Nếu thấy hay, hãy động viên và chia sẻ nhé! Các bình luận không phù hợp với nội quy bình luận trang web sẽ bị cấm bình luận vĩnh viễn.


Giải bài tập lớp 10 Kết nối tri thức khác
Tài liệu giáo viên