Trang chủ Tin Học Lớp 8 Nhập một số nguyên n.Tính tổng các ước của n...

Nhập một số nguyên n.Tính tổng các ước của n bằng phân tích thừa số nguyên tố code bằng c hoặc pas câu hỏi 4206530 - hoctapsgk.com

Câu hỏi :

Nhập một số nguyên n.Tính tổng các ước của n bằng phân tích thừa số nguyên tố code bằng c hoặc pas

Lời giải 1 :

#include <iostream>
using namespace std;

typedef long long ll;

ll pw(ll a, int n) {
    ll res = 1;
    while (n) {
        if (n & 1) res *= a;
        a *= a;
        n >>= 1;
    }
    return res;
}

ll f(ll a, int n) {
    return (pw(a, n + 1) - 1) / (a - 1);
}

ll calc(ll x) {
    ll res = 1;
    for (int i = 2; i * i <= x; i = i + 1 + (i & 1)) {
        int cnt = 0;
        while (x % i == 0) x /= i, cnt++;
        if (cnt) res *= f(i, cnt);
    }
    if (x != 1) res *= f(x, 1);
    return res;
}

int main() {
    ll n; cin >> n;
    cout << calc(n);
}

Thảo luận

-- bbi cũ của programmer ;-;
-- https://hoidap247.com/cau-hoi/4207395 Giúp em với
-- thanks

Lời giải 2 :

uses crt;

var i,n,s: integer;

function nt(n: integer): boolean;

var i,d: integer;

begin

d:=0;

for i:=1 to n do

if n mod i=0 then d:=d+1;

if d=2 then nt:=true else nt:=false;

end;

begin

clrscr;

write ('nhap n: ');  readln (n);

for i:=1 to n do if nt(i) then s:=s+i;

writeln ('tong la: ',s);

readln;

end. 

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

Lớp 8 - Năm thứ ba ở cấp trung học cơ sở, học tập bắt đầu nặng dần, sang năm lại là năm cuối cấp áp lực lớn dần nhưng các em vẫn phải chú ý sức khỏe 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