C++ Nhập vào 2 số nguyên a, b. Tìm ước chung lớn nhất và bội chung nhỏ nhất của 2 số đó

ADS
thumb up 0
thumb down
Trả lời câu hỏi của Nguyễn Thị Yến Nhi
  • Câu trả lời phải chính xác, đầy đủ dựa trên kiến thức xác thực:
    • ✔ Đối với câu hỏi trắc nghiệm: Đưa đáp án lựa chọn + giải thích lý do chọn đáp án.
    • ✔ Đối với câu hỏi tự luận: Đưa lời giải và đáp án cho câu hỏi.
    • ✔ Đối với câu hỏi trả lời ngắn: Đưa ra đáp án + giải thích lý do.
    • ✔ Chấp nhận sử dụng ảnh do thành viên viết tay, ảnh cần rõ nét, không bị mờ, vỡ ảnh.
  • Sử dụng ngôn ngữ rõ ràng, dễ hiểu.
  • Tránh đưa ra các ý kiến cá nhân mang tính chất chủ quan.
  • Nếu sử dụng thông tin từ nguồn khác, phải trích dẫn nguồn đầy đủ và chính xác.
  • Tuyệt đối không được sao chép các thông tin từ các trang khác, từ AI hoặc chatGPT.
ADS
CÂU TRẢ LỜI
avatar
Timi

08/02/2025

Trợ lý học tập AI - Câu trả lời này chỉ mang tính tham khảo
Để tìm ước chung lớn nhất (UCLN) và bội chung nhỏ nhất (BCNN) của hai số nguyên a và b trong C++, bạn có thể sử dụng thuật toán Euclid để tính UCLN, và sau đó tính BCNN dựa vào UCLN. Dưới đây là một đoạn mã mẫu: ```cpp #include <iostream> using namespace std; // Hàm tính UCLN int UCLN(int a, int b) { while (b != 0) { int temp = b; b = a % b; a = temp; } return a; } // Hàm tính BCNN int BCNN(int a, int b) { return (a * b) / UCLN(a, b); } int main() { int a, b; cout << "Nhập vào số nguyên a: "; cin >> a; cout << "Nhập vào số nguyên b: "; cin >> b; int ucln = UCLN(a, b); int bcnn = BCNN(a, b); cout << "Ước chung lớn nhất của " << a << " và " << b << " là: " << ucln << endl; cout << "Bội chung nhỏ nhất của " << a << " và " << b << " là: " << bcnn << endl; return 0; } ``` ### Giải thích: 1. **Hàm UCLN**: Sử dụng thuật toán Euclid để tìm UCLN của hai số. 2. **Hàm BCNN**: Tính BCNN bằng công thức: . 3. **Hàm main**: Nhập hai số nguyên từ người dùng và in ra UCLN và BCNN. Bạn có thể biên dịch và chạy đoạn mã này để kiểm tra kết quả.
Hãy giúp mọi người biết câu trả lời này thế nào?
0/5 (0 đánh giá)
thumb up 0
thumb down
0 bình luận
Bình luận

#include <iostream>
#include <numeric> // For std::gcd and std::lcm (C++17 and later)

// Function to calculate Greatest Common Divisor (GCD) using Euclidean algorithm
int gcd(int a, int b) {
   while (b != 0) {
       int temp = b;
       b = a % b;
       a = temp;
   }
   return a;
}

// Function to calculate Least Common Multiple (LCM)
int lcm(int a, int b) {
   return (a * b) / gcd(a, b);
}

int main() {
   int a, b;

   std::cout << "Enter two integers a and b: ";
   std::cin >> a >> b;

   // Calculate GCD
   int greatestCommonDivisor = gcd(a, b);
   std::cout << "Greatest Common Divisor (GCD) of " << a << " and " << b << " is: " << greatestCommonDivisor << std::endl;

   // Calculate LCM
   int leastCommonMultiple = lcm(a, b);
   std::cout << "Least Common Multiple (LCM) of " << a << " and " << b << " is: " << leastCommonMultiple << std::endl;

   // Alternative using C++17 <numeric> library:
   // int greatestCommonDivisorCpp17 = std::gcd(a, b);
   // int leastCommonMultipleCpp17 = std::lcm(a, b);
   // std::cout << "GCD (C++17): " << greatestCommonDivisorCpp17 << std::endl;
   // std::cout << "LCM (C++17): " << leastCommonMultipleCpp17 << std::endl;


   return 0;
}
Explanation and Improvements:

Include <iostream>: This is necessary for input and output operations (like std::cout and std::cin).
GCD Function (Euclidean Algorithm): The gcd() function efficiently calculates the Greatest Common Divisor using the Euclidean algorithm. This is the standard and most efficient way to find the GCD.
LCM Function: The lcm() function calculates the Least Common Multiple using the relationship: LCM(a, b) = (a * b) / GCD(a, b).
Input: The program prompts the user to enter two integers a and b.
Output: The program then prints the calculated GCD and LCM of the two numbers.
C++17 <numeric> Library (Optional): If you are using C++17 or a later standard, you can use the <numeric> library's std::gcd and std::lcm functions directly. The commented-out code in main() demonstrates this. This is the most concise and preferred approach if you have C++17 available. I've included the manual GCD/LCM functions as well, for instances where the C++17 library may not be available.
Error Handling (Consideration): For more robust code, you might want to add error handling to check if the user inputs valid integers. You can use std::cin.fail() to detect invalid input.

Hãy giúp mọi người biết câu trả lời này thế nào?
0/5 (0 đánh giá)
thumb up 0
thumb down
0 bình luận
Bình luận
ADS

Nếu bạn muốn hỏi bài tập

Các câu hỏi của bạn luôn được giải đáp dưới 10 phút

Ảnh ads

CÂU HỎI LIÊN QUAN

logo footer
FQA.vn Nền tảng kết nối cộng đồng hỗ trợ giải bài tập học sinh trong khối K12. Sản phẩm được phát triển bởi CÔNG TY TNHH CÔNG NGHỆ GIA ĐÌNH (FTECH CO., LTD)
Điện thoại: 1900636019 Email: info@fqa.vn
Location Địa chỉ: Số 21 Ngõ Giếng, Phố Đông Các, Phường Ô Chợ Dừa, Quận Đống Đa, Thành phố Hà Nội, Việt Nam.
Tải ứng dụng FQA
app store ch play
Người chịu trách nhiệm quản lý nội dung: Nguyễn Tuấn Quang Giấy phép thiết lập MXH số 07/GP-BTTTT do Bộ Thông tin và Truyền thông cấp ngày 05/01/2024
Copyright © 2023 fqa.vn All Rights Reserved
gift-box
survey
survey
Đặt câu hỏi