Trang chủ Tin Học Lớp 10 Nhập vào số n,kiểm tra số n có phải số...

Nhập vào số n,kiểm tra số n có phải số nguyên tố không ( dùng cách tối ưu nhất có thể nhé),code c++ câu hỏi 3519220 - hoctapsgk.com

Câu hỏi :

Nhập vào số n,kiểm tra số n có phải số nguyên tố không ( dùng cách tối ưu nhất có thể nhé),code c++

Lời giải 1 :

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

const int lim = 1e6;

int n;
vector<int> p(lim + 1, 1);

void sieve() {
    p[0] = p[1] = 0;
    for(int i = 2; i * i <= lim; ++i) {
        if(p[i]) {
            for(int j = i * i; j <= lim; j += i) p[j] = 0;
        }
    }
}

int main() {
    sieve();

    cin >> n;
    cout << (p[n] ? "YES" : "NO");
}

Thảo luận

-- Bạn làm theo kiểu bình thường đc không ạ,mình chưa học vector =((
-- Bạn đổi thành mảng, int p[lim + 1], rồi ở trong phần sàng sieve bạn memset(p, 1, lim + 1)
-- Oh thanks nha
-- kiểm tra 1 số mà sàng thì làm sao nhanh hơn thường được em?
-- Để em dùng cách khác ạ.
-- @nguyenvanphan05 bạn có thể dùng cách này nhé: #include <iostream> using namespace std; int prime(int n) { if(n < 2) return 0; if(n < 4) return 1; if(n % 2 == 0 || n % 3 == 0) return 0; for(int i = 5; i * i <= n; i += 6) { if(n... xem thêm
-- Oh ok nha bạn

Lời giải 2 :

*Đây là cách tối ưu nhất mình nghĩ ra (tìm ước (chạy tới $\sqrt{n}$))

#include <bits/stdc++.h>
using namespace std;
long long n;
int main()
{
    cin >> n;
    bool kt=true;
    for (long long i=2; i<=sqrt(n); i++)
        if (n%i==0)
        {
            kt=false;
            break;
        }
    if (kt==true)
        cout << n << " la so nguyen to";
    else
        cout << n << " khong la so nguyen to";
}

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

Lớp 10 - Năm thứ nhất ở cấp trung học phổ thông, năm đầu tiên nên có nhiều bạn bè mới đến từ những nơi xa hơn vì ngôi trường mới lại mỗi lúc lại xa nhà mình hơn. Được biết bên ngoài kia là một thế giới mới to và nhiều điều thú vị, một trang mới đang chò đợi chúng ta.

Nguồn : ADMIN :))

Copyright © 2021 HOCTAP247