LH Quảng cáo: lazijsc@gmail.com

Bài tập  /  Bài đang cần trả lời

Viết hàm UCLN(a, b) để tính ước chung lớn nhất của hai số nguyên dương a và b

Viết hàm UCLN(a, b) để tính ước chung lớn nhất của hai số nguyên dương a và b
3 trả lời
Hỏi chi tiết
121
2
1
Ozzy TK
21/05/2023 08:09:38
+5đ tặng
Để tính ước chung lớn nhất (UCLN) của hai số nguyên dương a và b, ta có thể sử dụng thuật toán Euclid. Dưới đây là một hàm Python để tính UCLN của hai số nguyên dương:

```python
def UCLN(a, b):
    while b != 0:
        a, b = b, a % b
    return a
```

Giải thích:
- Trong thuật toán Euclid, chúng ta sử dụng phép chia lấy dư để tìm UCLN.
- Ta lặp lại việc chia lấy dư cho đến khi số bằng 0. Khi đó, số hiện tại (a) sẽ là UCLN của hai số ban đầu (a và b).
- Trong mỗi vòng lặp, ta cập nhật giá trị của a thành b và giá trị của b thành a chia lấy dư cho b.
- Cuối cùng, ta trả về giá trị a là UCLN của hai số nguyên dương a và b.

Để sử dụng hàm trên, bạn có thể gọi nó với các giá trị a và b của bạn:

```python
a = 24
b = 36
ucln = UCLN(a, b)
print("UCLN của", a, "và", b, "là", ucln)
```

Kết quả sẽ là: "UCLN của 24 và 36 là 12".

Mở khóa để xem toàn bộ nội dung trả lời

(?)
Bạn đã đạt đến giới hạn của mình. Bằng cách Đăng ký tài khoản, bạn có thể xem toàn bộ nội dung trả lời
Cải thiện điểm số của bạn bằng cách đăng ký tài khoản Lazi.
Xem toàn bộ các câu trả lời, chat trực tiếp 1:1 với đội ngũ Gia sư Lazi bằng cách Đăng nhập tài khoản ngay bây giờ
Tôi đã có tài khoản? Đăng nhập
2
1
Phuonggg
21/05/2023 08:11:53
+4đ tặng

Hàm có thể viết như sau:

def UCLN(m,n):

 while m! = n:

  if m > n:

   m = m – n

  else

   n = n – m

 return m

3
0

Bạn hỏi - Lazi trả lời

Bạn muốn biết điều gì?

GỬI CÂU HỎI
Học tập không giới hạn cùng học sinh cả nước và AI, sôi động, tích cực, trải nghiệm
Trắc nghiệm Tin học Lớp 10 mới nhất

Hôm nay bạn thế nào? Hãy nhấp vào một lựa chọn, nếu may mắn bạn sẽ được tặng 50.000 xu từ Lazi

Vui Buồn Bình thường

Học ngoại ngữ với Flashcard

×
Trợ lý ảo Trợ lý ảo
×
Gia sư Lazi Gia sư