Trang chủ Tin Học Lớp 9 C++ Số hoàn hảo Số hoàn hảo là số mà...

C++ Số hoàn hảo Số hoàn hảo là số mà tổng các ước của nó bằng 2 lần chính nó. Ví dụ: 6 là số hoàn hảo vì 6 có tổng ước là 1+2+3+6=12 = 2 lần số 6. Yêu cầu: Viế

Câu hỏi :

C++ Số hoàn hảo Số hoàn hảo là số mà tổng các ước của nó bằng 2 lần chính nó. Ví dụ: 6 là số hoàn hảo vì 6 có tổng ước là 1+2+3+6=12 = 2 lần số 6. Yêu cầu: Viết chương trình nhập vào số nguyên n. In ra chữ YES nếu n là số hoàn hảo, ngược lại ghi chữ NO Dữ liệu vào Một số nguyên dương n (n≤109). Kết quả In ra chữ YES nếu n là số hoàn hảo, ngược lại ghi chữ NO Sample Input 1 6 Sample Output 1 YES Sample Input 2 36 Sample Output 2 NO

Lời giải 1 :

#include <iostream>
#include <cmath>
using namespace std;

bool check(int n)
{
    int s = 1;
    int sqrtn = sqrt(n);
    for (int i = 2;i <= sqrtn;i++)
     if (n % i == 0)
      s += i, s += n/i;
    if (sqrtn*sqrtn == n)
     s -= sqrtn;
    if (s == n)
     return true;
    return false;
}
int main()
{
 int n;cin >> n;
 if (check(n) == true)
  cout << "YES";
 else cout << "NO"; 
}

Thảo luận

-- https://hoidap247.com/cau-hoi/2342630 bn bt chỉnh cái này ko

Lời giải 2 :

#include <bits/stdc++.h>
#define ll long long
using namespace std;

int main() {
    ll n;
    cin >> n;
    int sum = 1;
    //Truong hop co ban

    if(n <= 0) {
        cout << "NO";
    } else {

        //Cho i chay tu 2 den can bac nhi cua n
        //Neu n chia het cho i va i * i != n thi sum+=i + (n/i)
        //Vi o day, neu n chia het cho i va i * i khac nhau thi ta cong ca 2 cai
        //Con neu n chia het cho i va i * i = n (n la so chinh phuong) thi cong 1 cai
        for(int i = 2; i <= sqrt(n); i++) {
            if(n % i == 0 && i * i != n) sum+=i + (n / i);
            else if(n % i == 0 && i * i == n) sum+=i;
        }

        //Neu tong uoc = n thi in YES, else in NO
        if(sum == n) {
            cout << "YES";
        } else {
            cout << "NO";
        }
    }
}

Bạn có biết?

Tin học, tiếng Anh: informatics, tiếng Pháp: informatique, là một ngành khoa học chuyên nghiên cứu quá trình tự động hóa việc tổ chức, lưu trữ, xử lý và truyền dẫn thông tin của một hệ thống máy tính cụ thể hoặc trừu tượng (ảo). Với cách hiểu hiện nay, tin học bao hàm tất cả các nghiên cứu và kỹ thuật có liên quan đến việc mô phỏng, biến đổi và tái tạo thông tin.

Nguồn : Wikipedia - Bách khoa toàn thư

Tâm sự 9

Lớp 9 - Là năm cuối ở cấp trung học cơ sở, sắp phải bước vào một kì thi căng thẳng và sắp chia tay bạn bè, thầy cô và cả kì vọng của phụ huynh ngày càng lớn mang tên "Lên cấp 3". Thật là áp lực nhưng các em hãy cứ tự tin vào bản thân là sẻ vượt qua nhé!

Nguồn : ADMIN :))

Liên hệ hợp tác hoặc quảng cáo: gmail

Điều khoản dịch vụ

Copyright © 2021 HOCTAPSGK