Home > C / C++ > Bài tập C++ > Đếm số nguyên tố có trong mảng một chiều các số nguyên bằng C / C++

Đếm số nguyên tố có trong mảng một chiều các số nguyên bằng C / C++

Trong bài viết này chúng ta sẽ thực hiện chương trình đếm số nguyên tố có trong mảng một chiều các số nguyên bằng C / C++.

Mình sẽ thực hiện hai chương trình để đếm với hai ngôn ngữ khác nhau đó là C và C++. Vì vậy các bạn cần có kiến thức cơ bản về hai ngôn ngữ này đã nhé!!

Đếm số nguyên tố có trong mảng một chiều các số nguyên bằng C

Đầu tiên ta cần tạo các hàm nhập xuất các phần tử cho mảng. Rồi tạo thêm hàm kiểm tra số nguyên tố và đếm số phần tử là số nguyên tố trong mảng.

Hàm nhập các phần tử:

Hàm nhap() sẽ có hai đối số là một mảng các số nguyên và biến n là số lượng phần tử trong mảng.

Ta sử dụng vòng lặp do..while để yêu cầu người dùng nhập vào số lượng phần tử của mảng trong khoảng từ 1 -> MAX. Nếu nhập khác thì yêu cầu nhập lại.

Tiếp đến sử dụng vòng lặp for để nhập giá trị cho từng phần tử của mảng.

void nhap (int a[], int &n)
{
  //sử dụng vòng lặp do..while để yêu cầu người dùng nhập vào số lương phần tử trong mảng
    do
    {
        printf("\nNhập số phần tử trong mảng: ");
        scanf("%d", &n);
        //nếu người dùng nhập vào số lượng <= 0 hoặc > MAX thì yêu cầu nhập lại
        if(n <= 0 || n > MAX)
        {
            printf("\nSố phần tử không hợp lệ, vui lòng nhập lại !");
        }
    }while(n <= 0 || n > MAX);
    //sử dụng vòng lặp for để nhập giá trị cho từng phần tử trong mảng
    for(int i = 0; i < n; i++)
    {
        printf("\nNhập a[%d]: ", i);
        scanf("%d", &a[i]);
    }
}

Hàm xuất các phần tử:

Đối với hàm xuat() ta cũng có hai đối số là mảng số nguyên và n số lượng phần tử của mảng.

Để xuất các phần tử trong mảng, đơn giản ta chỉ cần sử dụng vòng lặp for lặp từ đầu đến cuối mảng. Cứ mỗi lần lặp như vậy ta in phần tử thứ a[i] ra màn hình.

void xuat(int a[], int n)
{
  //sử dụng vòng lặp for lặp từ đầu mảng đến cuối mảng, cứ mỗi vòng lặp ta in phần tử đó ra màn hình
    printf("Các phần tử trong mảng: \n");
    for(int i = 0; i < n; i++)
    {
        printf("%4d", a[i]);
    }
}

Hàm kiểm tra số nguyên tố:

Hàm KiemTraNguyenTo() sẽ nhận đối số là một số nguyên, rồi thực hiện các điều kiện số nguyên tố. Nếu là số nguyên tố thì trả về true và ngược lại sẽ trả về false.

bool KiemTraNguyenTo(int n)
{
  //nếu n < 2 thì không phải là số nguyên tố
    if (n < 2)
    {
        return false;
    }
    //nếu n > 2 thì ta tiếp tục xét
    else if (n > 2)
    {
      //nếu n % 2 == 0 thì không phải là số nguyên tố
        if (n % 2 == 0) 
        {
            return false;
        }
        //ta sử dụng vòng lặp for lặp từ 3 đến căn bậc hai của n, với bước nhảy += 2
        for (int i = 3; i <= sqrt((float)n); i += 2) 
        {
          //nếu n chia hết cho i thì không phải là số nguyên tố
            if (n % i == 0)
            {
                return false;
            }
        }
    }
    //còn lại là số nguyên tố
    return true;

Hàm đếm số nguyên tố:

Ta tạo một biến dem = 0 để đếm số lượng số nguyên tố trong mảng.

Sử dụng vòng lặp for lặp từ 0 đến n với bước nhảy là i++. Gọi hàm KiemTraNguyenTo() để kiểm tra từng phần tử a[i] trong mảng, nếu là số nguyên tố thì tăng biến dem++.

Sau khi kết thúc vòng lặp ta sẽ được biến dem là số lượng số nguyên tố có trong mảng.

int demnguyento(int a[], int n)
{
    int dem = 0;
    //ta sử dụng vòng lặp for để duyệt từng phần tử trong mảng
    //cứ mỗi vòng lặp ta gọi hàm KiemTraNguyenTo() để kiểm tra phần tử đó, nếu phải thì biến dem++
    for(int i = 0; i < n; i++)
    {
        if(KiemTraNguyenTo(a[i]) == true && a[i] < 100)
        {
            dem++;
        }
    }
    //sau khi kết thúc vòng lặp thì ta return dem (số phần tử trong mảng là số nguyên tố)
    return dem;
}

Dưới đây mình đã viêt sẵn chương trình đếm số nguyên tố có trong mảng một chiều các số nguyên bằng C, các bạn có thể tham khảo nhé !!!

Code:

#include<stdio.h>
#include<math.h>
#define MAX 100
/* hàm nhập các phần tử trong mảng */
void nhap (int a[], int &n)
{
  //sử dụng vòng lặp do..while để yêu cầu người dùng nhập vào số lương phần tử trong mảng
    do
    {
        printf("\nNhập số phần tử trong mảng: ");
        scanf("%d", &n);
        //nếu người dùng nhập vào số lượng <= 0 hoặc > MAX thì yêu cầu nhập lại
        if(n <= 0 || n > MAX)
        {
            printf("\nSố phần tử không hợp lệ, vui lòng nhập lại !");
        }
    }while(n <= 0 || n > MAX);
    //sử dụng vòng lặp for để nhập giá trị cho từng phần tử trong mảng
    for(int i = 0; i < n; i++)
    {
        printf("\nNhập a[%d]: ", i);
        scanf("%d", &a[i]);
    }
}
/* hàm xuất các phần tử trong mảng */
void xuat(int a[], int n)
{
  //sử dụng vòng lặp for lặp từ đầu mảng đến cuối mảng, cứ mỗi vòng lặp ta in phần tử đó ra màn hình
    printf("Các phần tử trong mảng: \n");
    for(int i = 0; i < n; i++)
    {
        printf("%4d", a[i]);
    }
}
/* hàm kiếm tra số nguyên tố */
bool KiemTraNguyenTo(int n)
{
  //nếu n < 2 thì không phải là số nguyên tố
    if (n < 2)
    {
        return false;
    }
    //nếu n > 2 thì ta tiếp tục xét
    else if (n > 2)
    {
      //nếu n % 2 == 0 thì không phải là số nguyên tố
        if (n % 2 == 0) 
        {
            return false;
        }
        //ta sử dụng vòng lặp for lặp từ 3 đến căn bậc hai của n, với bước nhảy += 2
        for (int i = 3; i <= sqrt((float)n); i += 2) 
        {
          //nếu n chia hết cho i thì không phải là số nguyên tố
            if (n % i == 0)
            {
                return false;
            }
        }
    }
    //còn lại là số nguyên tố
    return true;
}
/* hàm đếm số nguyên tố trong mảng */
int demnguyento(int a[], int n)
{
    int dem = 0;
    //ta sử dụng vòng lặp for để duyệt từng phần tử trong mảng
    //cứ mỗi vòng lặp ta gọi hàm KiemTraNguyenTo() để kiểm tra phần tử đó, nếu phải thì biến dem++
    for(int i = 0; i < n; i++)
    {
        if(KiemTraNguyenTo(a[i]) == true && a[i] < 100)
        {
            dem++;
        }
    }
    //sau khi kết thúc vòng lặp thì ta return dem (số phần tử trong mảng là số nguyên tố)
    return dem;
}
int main()
{
    int n;
    int a[MAX];
    nhap(a, n);
    xuat(a, n);
    int dem = demnguyento(a, n);
    printf("\nSố lượng số nguyên tố trong mảng: %d", dem);

    printf("\n-----------------------------------\n");
    printf("Chương trình này được đăng tại Freetuts.net");
}

Kết quả:

bai59 01 PNG

Đếm số nguyên tố có trong mảng một chiều các số nguyên bằng C++

Việc đếm số nguyên tố có trong mảng một chiều các số nguyên bằng C++ cũng tương tự như ngôn ngữ C. Vì về cơ bản thì hai ngôn ngữ này khá tương đồng nhau.

Các bạn chỉ cần thay thế printf() và scanf() trong ngôn ngữ C bằng cout() và cin() trong ngôn ngữ C++. Nhớ khai báo thư viện <iostream> trước khi sử dụng cout() và cin() nhé!!!

#include <iostream>
#include<math.h>
using namespace std;
#define MAX 100
/* hàm nhập các phần tử trong mảng */
void nhap (int a[], int &n)
{
  //sử dụng vòng lặp do..while để yêu cầu người dùng nhập vào số lương phần tử trong mảng
    do
    {
        cout<<"\nNhập số phần tử trong mảng: ";
        cin>>n;
        //nếu người dùng nhập vào số lượng <= 0 hoặc > MAX thì yêu cầu nhập lại
        if(n <= 0 || n > MAX)
        {
            cout<<"\nSố phần tử không hợp lệ, vui lòng nhập lại !";
        }
    }while(n <= 0 || n > MAX);
    //sử dụng vòng lặp for để nhập giá trị cho từng phần tử trong mảng
    for(int i = 0; i < n; i++)
    {
        cout<<"\nNhập a["<<i<<"]: ";
        cin>>a[i];
    }
}
/* hàm xuất các phần tử trong mảng */
void xuat(int a[], int n)
{
  //sử dụng vòng lặp for lặp từ đầu mảng đến cuối mảng, cứ mỗi vòng lặp ta in phần tử đó ra màn hình
    cout<<"Các phần tử trong mảng: \n";
    for(int i = 0; i < n; i++)
    {
        cout<<a[i]<<"\t";
    }
}
/* hàm kiếm tra số nguyên tố */
bool KiemTraNguyenTo(int n)
{
  //nếu n < 2 thì không phải là số nguyên tố
    if (n < 2)
    {
        return false;
    }
    //nếu n > 2 thì ta tiếp tục xét
    else if (n > 2)
    {
      //nếu n % 2 == 0 thì không phải là số nguyên tố
        if (n % 2 == 0) 
        {
            return false;
        }
        //ta sử dụng vòng lặp for lặp từ 3 đến căn bậc hai của n, với bước nhảy += 2
        for (int i = 3; i <= sqrt((float)n); i += 2) 
        {
          //nếu n chia hết cho i thì không phải là số nguyên tố
            if (n % i == 0)
            {
                return false;
            }
        }
    }
    //còn lại là số nguyên tố
    return true;
}
/* hàm đếm số nguyên tố trong mảng */
int demnguyento(int a[], int n)
{
    int dem = 0;
    //ta sử dụng vòng lặp for để duyệt từng phần tử trong mảng
    //cứ mỗi vòng lặp ta gọi hàm KiemTraNguyenTo() để kiểm tra phần tử đó, nếu phải thì biến dem++
    for(int i = 0; i < n; i++)
    {
        if(KiemTraNguyenTo(a[i]) == true && a[i] < 100)
        {
            dem++;
        }
    }
    //sau khi kết thúc vòng lặp thì ta return dem (số phần tử trong mảng là số nguyên tố)
    return dem;
}
int main()
{
    int n;
    int a[MAX];
    nhap(a, n);
    xuat(a, n);
    int dem = demnguyento(a, n);
    cout<<"\nSố lượng số nguyên tố trong mảng: "<<dem;

    cout<<"\n-----------------------------------\n";
    cout<<"Chương trình này được đăng tại Freetuts.net";
}

Kết quả:

bai59 02 PNG

Như vậy là chúng ta đã thực hiện xong chương trình đếm số nguyên tố có trong mảng một chiều các số nguyên bằng C / C++. Các bạn có thể tham khảo các bài tập khác tại Tổng hợp 1000 bài tập C / C++ nhé, chúc các bạn thành công !!!

Bình luận đã đóng, nếu có thắc mắc hãy đặt câu hỏi tại hoicode.com để admin trả lời.

Nguồn: freetuts.net

Tham khảo
Tính S(n) = 1 + 2 + 3 + … + n bằng C / C++
Tính S(n) = 1^2 + 2^2 + … + n^2 bằng C / C++
Tính S(n) = 1 + 1/2 + 1/3 + … + 1/n bằng C / C++
Tính S(n) = 1/2 + 1/4 + … + 1/2n bằng C / C++
Tính S(n) = 1 + 1/3 + 1/5 + … + 1/(2n - 1) bằng C / C++
Tính S(n) = 1/(1×2) + 1/(2×3) +…+ 1/(n x (n + 1)) bằng C / C++
Tính S(n) = 1/2 + 2/3 + 3/4 + …. + n / (n + 1) bằng C / C++
Tính S(n) = 1/2 + 3/4 + 5/6 + … + (2n + 1)/( 2n + 2) bằng C / C++
Tính T(n) = 1 x 2 x 3…x N bằng C / C++
Tính T(x, n) = x^n bằng C / C++
Tính S(n) = 1 + 1.2 + 1.2.3 + … + 1.2.3….N bằng C / C++
Tính S(n) = x + x^2 + x^3 + … + x^n bằng C / C++
Tính S(n) = x^2 + x^4 + … + x^2n bằng C / C++
Tính S(n) = x + x^3 + x^5 + … + x^(2n - 1) bằng C / C++
Tính tổng tất cả các “ước số” của số nguyên dương n bằng C / C++
Tính tích tất cả các “ước số” của số nguyên dương n bằng C / C++
Liệt kê tất cả các ước số lẻ của số nguyên dương n bằng C / C++
Tính tổng tất cả các ước số chẵn của số nguyên dương n bằng C / C++
Tìm ước số lẻ lớn nhất của số nguyên dương n bằng C / C++
Đếm số lượng chữ số của số nguyên dương n bằng C / C++
Tính tích các chữ số của số nguyên dương n bằng C++
Đếm số lượng chữ số lẻ của số nguyên dương n bằng C / C++
Tính tổng các chữ số chẵn của số nguyên dương n bằng C / C++
Tìm chữ số đầu tiên của số nguyên dương n bằng C / C++
Tìm chữ số lớn nhất của số nguyên dương n bằng C / C++
Tìm chữ số nhỏ nhất của số nguyên dương n bằng C / C++
Đếm chữ số lớn nhất của số nguyên dương n bằng C / C++
Đếm chữ số nhỏ nhất của số nguyên dương n bằng C / C++
Kiểm tra số n có toàn chữ số lẻ hay không bằng C / C++
Kiểm tra số n có toàn chữ số chẵn hay không bằng C / C++
Kiểm tra các chữ số của số n có tăng dần từ trái sang phải không bằng C / C++
Kiểm tra các chữ số của số n có giảm dần hay không bằng C / C++
Tính S(x, n) = x – x^2 + x^3 + … + (-1)^n+1 * x^n bằng C / C++
Kiểm tra hai số thực có cùng dấu hay không bằng C / C++
Kiểm tra tháng thuộc quý nào bằng C / C++
Tính S(n) = 1^3 + 2^3 + … + N^3 bằng C / C++
Tìm số nguyên dương n nhỏ nhất sao cho 1 + 2 + … + n > 10000 bằng C / C++
Sử dụng vòng lặp for để xuất các ký tự từ A đến Z bằng C / C++
Tính tổng các giá trị lẻ nguyên dương nhỏ hơn N bằng C / C++
In tất cả các số nguyên dương lẻ nhỏ hơn 100 bằng C / C++
Kiểm tra loại tam giác gì bằng C / C++
Giải hệ phương trình bậc nhất hai ẩn bằng C / C++
Chương trình tìm số ngày trong tháng bằng C / C++
Nhập vào ngày tháng năm rồi in ra ngày tiếp theo bằng C / C++
Nhập vào ngày tháng năm rồi in ra ngày tháng năm trước đó bằng C / C++
In ra cách đọc của một số nguyên dương có hai chữ số bằng C / C++
In ra cách đọc của một số nguyên dương có ba chữ số bằng C / C++
Tính điểm trung bình của môn toán và môn văn bằng C / C++
Tìm phần tử lớn nhất trong mảng một chiều bằng C / C++
Tìm phần tử nhỏ nhất trong mảng một chiều bằng C / C++
Tìm vị trí của phần tử nhỏ nhất trong mảng một chiều bằng C / C++
Tìm vị trí của phần tử lớn nhất trong mảng một chiều bằng C / C++
Nhập, xuất mảng các số thực bằng C / C++
Nhập, xuất mảng các số nguyên bằng C / C++
Liệt kê các giá trị chẵn trong mảng các số nguyên bằng C / C++
Liệt kê các giá trị lẻ trong mảng các số nguyên bằng C / C++
Liệt kê vị trí các giá trị âm trong mảng một chiều các số thực bằng C / C++
Đếm số nguyên tố có trong mảng một chiều các số nguyên bằng C / C++
Tính tổng các giá trị âm trong mảng một chiều các số thực bằng C / C++

BÀI VIẾT

notice png LIST home png HOME hot gif BÁO
LỖI
top png TOP