
Anonymous
0
0
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
- asked 4 months agoVotes
0Answers
0Views
Giải SBT Tin học 10 Kết nối tri thứcBà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
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.
Trả lời:
Các em tự viết lại chương trình trên:
Kết quả chạy chương trình có thể như sau:
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)
Xem thêm lời giải sách bài tập Tin học lớp 10 bộ sách Kết nối tri thức hay, chi tiết nhất:
Xem thêm lời giải sách bài tập Tin học lớp 10 bộ sách Kết nối tri thức hay, chi tiết nhất:
Bài 29: Nhận biết lỗi chương trình
Bài 30: Kiểm thử và gỡ lỗi chương trình
Bài 32: Ôn tập lập trình Python