Bài Tập C - Tìm ước Số Chung Lớn Nhất (USCLN) Và Bội Số ... - VietTuts
Có thể bạn quan tâm
Nội dung chính
- Đề bài
- Định nghĩa
- Lời giải
- Tìm USCLN và BSCNN của 2 số a và b trong C
Đề bài
Viết chương trình C tìm ước số chung lớn nhất (USCLN) và bội số chung nhỏ nhất (BSCNN) của hai số nguyên dương a và b.
Định nghĩa
USCLN của 2 số nguyên dương a và b là một số k lớn nhất, sao cho a và b đều chia hết cho k.
BSCNN của 2 số nguyên dương a và b là một số h nhỏ nhất, sao cho h chia hết cho cả a và b.
Lời giải
Một phương pháp đơn giản đề tìm USCLN của a và b là duyệt từ số nhỏ hơn trong 2 số a và b cho đến 1, khi gặp số nào đó mà cả a và b đều chia hết cho nó thì đó chính là USCLN của a và b. Tuy vậy phương pháp này chưa phải là hiệu quả nhất.
Vào thế kỷ 3 TCN, nhà toán học Euclid (phiên âm tiếng Việt là Ơ-clit) đã phát minh ra một giải thuật tìm USCLN của hai số nguyên dương rất hiệu quả được gọi là giải thuật Euclid. Cụ thể về ý tưởng của bài toán, giả sử a lớn hơn b, khi đó việc tính UCSLN của a và b sẽ được đưa về bài toán tính USCLN của a mod b và b vì USCLN(a, b) = USCLN(a mod b, b).
Khi đã tìm được USCLN thì việc tìm BSCNN của hai số nguyên dương a và b khá đơn giản. Khi đó BSCNN(a, b) = (a * b) / UCSLN(a, b).
Tìm USCLN và BSCNN của 2 số a và b trong C
Ví dụ dưới đây sử dụng giải thuật Euclid để giải quyết bài toán tìm ước số chung lớn nhất (USCLN) và bội số chung nhỏ nhất (BSCNN) của hai số nguyên dương a và b.
/** * Chuong trinh tim uoc chung lon nhat (USCLN) * va boi so chung nho nhat (BSCNN) cua 2 so a và b * * @author viettuts.vn */ #include<stdio.h> /** * Tim uoc so chung lon nhat (USCLN) */ int USCLN(int a, int b) { if (b == 0) return a; return USCLN(b, a % b); } /** * Tim boi so chung nho nhat (BSCNN) */ int BSCNN(int a, int b) { return (a * b) / USCLN(a, b); } /** * Ham main */ int main() { int a, b; printf("Nhap so nguyen duong a = "); scanf("%d", &a); printf("Nhap so nguyen duong b = "); scanf("%d", &b); // tinh USCLN cua a và b printf("USCLN cua %d va %d la: %d", a, b, USCLN(a, b)); // tinh BSCNN cua a và b printf("USCLN cua %d va %d la: %d", a, b, BSCNN(a, b)); }Kết quả:
Nhap so nguyen duong a = 3 Nhap so nguyen duong b = 4 USCLN cua 3 va 4 la: 1 USCLN cua 3 va 4 la: 12 Giải phương trình bậc 2 trong C Liệt kê tất cả các số nguyên tố nhỏ hơn nTừ khóa » Cách Tìm Ucln Và Bcnn Của 2 Số
-
Tìm ước Số Chung Lớn Nhất Và Bội Số Chung Nhỏ Nhất Của A Và B
-
Cách Tìm ước Chung Lớn Nhất Của 2 Số Nhanh Chuẩn Không Cần Chỉnh
-
Cách Tìm ước Chung Lớn Nhất Của 2 Số - Top Lời Giải
-
Cách Tìm ước Chung Lớn Nhất (ƯCLN)
-
Cách Tìm Ước Chung Lớn Nhất (ƯCLN), Bội Chung Nhỏ Nhất (BCNN ...
-
Tổng Hợp Những Cách để Tìm 2 Số Khi Biết ƯCLN Và BCNN
-
Cách Tìm UCLN Và BCNN Trong Lập Trình C/C++
-
Tìm ƯCLN Và BCNN Của: Bài 2.55 Trang 56 Toán Lớp 6 Tập 1
-
Lý Thuyết ước Chung Lớn Nhất, Bội Chung Nhỏ Nhất Toán 6
-
Cách Tìm ước Chung Lớn Nhất Và Bội Chung Nhỏ Nhất - Abcdonline
-
[C++] Viết Chương Trình Tìm UCLN, BCNN Của 2 Số A, B
-
Bài 25. Tìm Bội Chung Nhỏ Nhất Của 2 Số - Lập Trình Không Khó
-
Ước Chung Lớn Nhất Và Các Bước Tìm ƯCLN - Giáo Viên Việt Nam
-
Casio Chuyên đề Tìm ước Chung Lớn Nhất (UCLN) Và Bội Chung Nhỏ ...