Trang chủ Tin Học Lớp 7 Hải là người rất thích các số nguyên tố. Lần...

Hải là người rất thích các số nguyên tố. Lần này, thầy giáo cho Hải một bài toán tưởng chừng như rất đơn giản nhưng lại đem đến cho hải một thử thách mới. Hải

Câu hỏi :

Hải là người rất thích các số nguyên tố. Lần này, thầy giáo cho Hải một bài toán tưởng chừng như rất đơn giản nhưng lại đem đến cho hải một thử thách mới. Hải đang khó khăn trong việc giải quyết bài toán này. Bài toán: Với cặp số tự nhiên 𝑛 cho trước, hãy đếm và liệt kê các số nguyên tố có giá trị không vượt quá 𝑛 và có độ cao đúng bằng . Biết rằng độ cao của một số tự nhiên là tổng các chữ số của số đó. Yêu cầu: Bạn hãy giúp Hải giải bài toán này nhé. Dữ liệu vào: Gồm hai số lần lượt là 𝑛 (10 𝑛 105 ) và (1 45) cách nhau 1 khoảng trắng. Kết quả: Gồm nhiều dòng, mỗi dòng là một số nguyên tố thỏa mãn yêu cầu của bài toán. Dòng cuối cùng ghi số lượng số nguyên tố vừa liệt kê. C++

Lời giải 1 :

#include <bits/stdc++.h>
using namespace std;
int sum(int n) {
    int s=0;
    while (n>0) {
        s+=n%10;
        n/=10;
    }
    return s;
}
bool nt(int n) {
    if (n<2) return false;
    for (int i=2; i<=sqrt(n); i++) if (n%i==0) return false;
    return true;
}
int main() {
    int n,k;
    cin >> n >> k;
    int d=0;
    for (int i=2; i<n; i++) if (sum(i)==k && nt(i)) {
        cout << i << endl;
        d++;
    }
    cout << d;
}

Thảo luận

Lời giải 2 :

`#`$include <bits/stdc++.h>$
$using$  $namespace$  $std;$
$int$ $sum(int$ $n)$ $\{$
    $int$ $s=0;$
    $while$  `(n>0)`  $\{$
        `s+=n%10;`
        `n``/=10;`
    `}`
    `return` `s;`
`}`
$bool$ `nt(`$int$  $n)$ {
    `if` `(n<2)` `return` `false;`
    $for$ $(int$ $i=2;$ $i<=sqrt(n);$ $i++)$ `if` `(n%i==0)` `return` `false;`
    `return` `true;`
`}`
$int$ $main()$ `{`
    $int$ `n,k;`
    $cin$ $>>$ `n` $>>$ `k;`
    $int$ `d=0;`
    $for$ $(int$ `i=2;` `i<n;` `i++)` `if` $(sum$`(i)==k` `&&` `nt(i))` `{`
        `cout` $<< i << endl;$
        `d++;`
    $\}$
    $cout$ $<< d;$
`}`

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

Lớp 7 - Năm thứ hai ở cấp trung học cơ sở, một cuồng quay mới lại đến vẫn bước tiếp trên đường đời học sinh. Học tập vẫn là nhiệm vụ chí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