Bài 21. Đếm số đẹp  Tên file: CNUMBER.*** Đếm số lượng các số đẹp nhỏ hơn hoặc bằng n (n ≤ 100000). Ở đây, số đẹp được định nghĩa như định nghĩa số đẹp trong bài 17. Input: số nguyên dương n Outpu...

Trả lời câu hỏi của Quoc Anh Le Tran

Làm sao để có câu trả lời hay nhất?

  • Luôn có GIẢI THÍCH các bước giải
  • Không copy câu trả lời của Timi
  • Không sao chép trên mạng
  • Không spam câu trả lời để nhận điểm
  • Spam sẽ bị khóa tài khoản
CÂU TRẢ LỜI
avatar
Timi

8 giờ trước

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 "Đếm số đẹp", trước tiên chúng ta cần hiểu rõ định nghĩa về số đẹp. Theo bài 17 mà bạn đã đề cập, số đẹp là số có chứa các chữ số 6 hoặc 8. Dưới đây là một đoạn mã C++ để đếm số lượng các số đẹp nhỏ hơn hoặc bằng n: ```cpp #include <iostream> using namespace std; // Hàm kiểm tra xem một số có phải là số đẹp hay không bool isBeautiful(int num) { while (num > 0) { int digit = num % 10; // Lấy chữ số cuối cùng if (digit == 6 || digit == 8) { return true; // Nếu có chữ số 6 hoặc 8 thì là số đẹp } num /= 10; // Bỏ chữ số cuối cùng } return false; // Nếu không có chữ số 6 hoặc 8 } int main() { int n; cout << "Nhập số nguyên dương n: "; cin >> n; int count = 0; // Biến đếm số đẹp for (int i = 1; i <= n; i++) { if (isBeautiful(i)) { count++; // Tăng biến đếm nếu i là số đẹp } } cout << count << endl; // In ra số lượng số đẹp return 0; } ``` ### Giải thích mã: 1. **Hàm `isBeautiful(int num)`**: Hàm này kiểm tra xem một số có phải là số đẹp hay không bằng cách kiểm tra từng chữ số của nó. 2. **Vòng lặp trong `main()`**: Vòng lặp từ 1 đến n để kiểm tra từng số và đếm số lượng số đẹp. 3. **Kết quả**: Cuối cùng, in ra số lượng số đẹp. Bạn có thể biên dịch và chạy đoạn mã này trong môi trường C++ để 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
avatar
level icon
Jung Hopi( J-Hope)

8 giờ trước

#include <iostream>

using namespace std;

int sumDigits(int n) {
   int sum = 0;
   while (n > 0) {
       sum += n % 10;
       n /= 10;
   }
   return sum;
}

bool isBeautifulNumber(int n) {
   return sumDigits(n) % 9 == 0;
}

int countBeautifulNumbers(int n) {
   int count = 0;
   for (int i = 1; i <= n; ++i) {
       if (isBeautifulNumber(i)) {
           count++;
       }
   }
   return count;
}

int main() {
   int n;
   cin >> n;
   cout << countBeautifulNumbers(n) << 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

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

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
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