cho 1 số được coi là số đối xứng và có từ 3 ước số nguyên tố khác nhau trở lên. cho 2 số a và b , đưa ra số lượng số đẹp trong đoạn từ a đến b giải theo c++

ADS
thumb up 0
thumb down
Trả lời câu hỏi của Huy Hoàng
  • 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

13/04/2023

Trợ lý học tập AI - Câu trả lời này chỉ mang tính tham khảo
Để giải bài toán này, ta cần phải tìm các số đối xứng có từ 3 ước số nguyên tố khác nhau trở lên. Sau đó, ta sẽ kiểm tra số lượng số đẹp trong đoạn từ a đến b. Đầu tiên, ta sẽ viết một hàm để kiểm tra xem một số có phải là số đối xứng hay không: ```cpp bool isPalindrome(int n) { int temp = n, reverse = 0; while (temp != 0) { reverse = reverse * 10 + temp % 10; temp /= 10; } return n == reverse; } ``` Hàm này sẽ trả về true nếu số đó là số đối xứng và false nếu không phải. Tiếp theo, ta sẽ viết một hàm để kiểm tra xem một số có từ 3 ước số nguyên tố khác nhau trở lên hay không: ```cpp bool hasThreeDistinctPrimeFactors(int n) { int count = 0; for (int i = 2; i <= n / i; i++) { while (n % i == 0) { count++; n /= i; } } if (n > 1) { count++; } return count >= 3; } ``` Hàm này sẽ trả về true nếu số đó có từ 3 ước số nguyên tố khác nhau trở lên và false nếu không phải. Sau khi có hai hàm trên, ta sẽ dùng vòng lặp để tìm các số đối xứng có từ 3 ước số nguyên tố khác nhau trở lên trong đoạn từ a đến b: ```cpp int count = 0; for (int i = a; i <= b; i++) { if (isPalindrome(i) && hasThreeDistinctPrimeFactors(i)) { count++; } } ``` Cuối cùng, ta sẽ trả về số lượng số đẹp trong đoạn từ a đến b: ```cpp return count; ``` Vậy đây là toàn bộ code giải bài toán: ```cpp bool isPalindrome(int n) { int temp = n, reverse = 0; while (temp != 0) { reverse = reverse * 10 + temp % 10; temp /= 10; } return n == reverse; } bool hasThreeDistinctPrimeFactors(int n) { int count = 0; for (int i = 2; i <= n / i; i++) { while (n % i == 0) { count++; n /= i; } } if (n > 1) { count++; } return count >= 3; } int countBeautifulNumbers(int a, int b) { int count = 0; for (int i = a; i <= b; i++) { if (isPalindrome(i) && hasThreeDistinctPrimeFactors(i)) { count++; } } return count; } ```
Hãy giúp mọi người biết câu trả lời này thế nào?
3.0/5 (1 đánh giá)
thumb up 0
thumb down
0 bình luận
Bình luận
avatar
level icon
minhanhpham

13/04/2023

#include <iostream>

#include <cmath>

using namespace std;


// Kiểm tra xem một số có phải số đối xứng hay không

bool isPalindrome(int n) {

   int m = n, rev = 0;

   while (m) {

       rev = rev * 10 + m % 10;

       m /= 10;

   }

   return n == rev;

}


// Kiểm tra xem một số có bao nhiêu ước số nguyên tố khác nhau

int countDistinctPrimeFactors(int n) {

   int count = 0;

   for (int i = 2; i <= sqrt(n); i++) {

       if (n % i == 0) {

           count++;

           while (n % i == 0) {

               n /= i;

           }

       }

   }

   if (n > 1) {

       count++;

   }

   return count;

}


// Kiểm tra xem một số có phải số đẹp hay không

bool isBeautiful(int n) {

   return isPalindrome(n) && countDistinctPrimeFactors(n) >= 3;

}


int main() {

   int a, b, count = 0;

   cout << "Nhap vao hai so a, b: ";

   cin >> a >> b;

   for (int i = a; i <= b; i++) {

       if (isBeautiful(i)) {

           count++;

       }

   }

   cout << "So luong so dep trong doan tu " << a << " den " << b << " la: " << count << endl;

   return 0;

}

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