如何用C語言求素數

一、素數的概念

素數是指在大於1的自然數中,除了1和它本身以外,不能被其他自然數整除的數。比如2、3、5、7等都是素數。

為了方便,我們用n代表待判斷的數。判斷n是否為素數,就是判斷n能否被2到n-1之間的任何一個數整除,如果不能,那麼n就是素數。

二、常見的求素數算法

1. 直接判斷法

bool is_prime(int n){
    if(n <= 1){  //小於等於1的數不是素數
        return false;
    }
    for(int i=2; i<n; i++){
        if(n % i == 0){  //如果n能被i整除,那麼n不是素數
            return false;
        }
    }
    return true;
}

直接判斷法是一種比較簡單的方法,但是對於大的素數來說,速度會比較慢。

2. 厄拉多塞篩法

厄拉多塞篩法的基本思想是從2開始,將每個素數的倍數都標記為合數,以達到篩選素數的目的。具體步驟如下:

(1)先將 2~n 中的所有整數寫下來;

(2)先把 2 的倍數都打上標記,除了2;

(3)再把 3 的倍數都打上標記,除了3;

(4)接着找下一個素數 5,重複上述過程;

(5)一直重複下去,直到某個數的平方大於n為止。此時,還沒有被標記的數就是素數。

void prime_sieve(int n, bool *is_prime){
    memset(is_prime, true, (n+1)*sizeof(bool));
    is_prime[0] = false;
    is_prime[1] = false;
    for(int i=2; i*i<=n; i++){
        if(is_prime[i]){
            for(int j=i*i; j<=n; j+=i){
                is_prime[j] = false;
            }
        }
    }
}

三、比較兩種算法的效率

下面我們來比較一下這兩種算法的效率。測試數據為n=1,000,000。

#include 
#include 
#define N 1000000

int main(){
    bool is_pri[N+1];
    clock_t start, end;
    double duration;

    start = clock();
    prime_sieve(N, is_pri);
    end = clock();
    duration = (double)(end - start) / CLOCKS_PER_SEC;
    printf("prime_sieve: %.5fs\n", duration);

    start = clock();
    for(int i=1; i<=N; i++){
        is_prime(i);
    }
    end = clock();
    duration = (double)(end - start) / CLOCKS_PER_SEC;
    printf("is_prime: %.5fs\n", duration);

    return 0;
}

測試結果如下所示:

prime_sieve: 0.00800s
is_prime:  11.91400s

可以看出,厄拉多塞篩法的效率遠高於直接判斷法。

四、總結

求素數是算法中比較基礎的部分,在實際應用中也經常用到。本文介紹了兩種常見的求素數算法,包括直接判斷法和厄拉多塞篩法,並比較了它們的效率。用C語言實現求素數的過程也可以幫助讀者更好地理解算法的實現過程。

原創文章,作者:JGYOA,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/372964.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
JGYOA的頭像JGYOA
上一篇 2025-04-25 15:26
下一篇 2025-04-25 15:26

相關推薦

  • 如何用Python寫愛心

    本文將會從多個方面闡述如何用Python語言來畫一個美麗的愛心圖案。 一、準備工作 在開始編寫程序之前,需要先理解一些編程基礎知識。首先是繪圖庫。Python有很多繪圖庫,常見的有…

    編程 2025-04-29
  • 用不同的方法求素數

    素數是指只能被1和自身整除的正整數,如2、3、5、7、11、13等。素數在密碼學、計算機科學、數學、物理等領域都有着廣泛的應用。本文將介紹幾種常見的求素數的方法,包括暴力枚舉法、埃…

    編程 2025-04-29
  • AES加密解密算法的C語言實現

    AES(Advanced Encryption Standard)是一種對稱加密算法,可用於對數據進行加密和解密。在本篇文章中,我們將介紹C語言中如何實現AES算法,並對實現過程進…

    編程 2025-04-29
  • 如何用Python統計列表中各數據的方差和標準差

    本文將從多個方面闡述如何使用Python統計列表中各數據的方差和標準差, 並給出詳細的代碼示例。 一、什麼是方差和標準差 方差是衡量數據變異程度的統計指標,它是每個數據值和該數據值…

    編程 2025-04-29
  • 學習Python對學習C語言有幫助嗎?

    Python和C語言是兩種非常受歡迎的編程語言,在程序開發中都扮演着非常重要的角色。那麼,學習Python對學習C語言有幫助嗎?答案是肯定的。在本文中,我們將從多個角度探討Pyth…

    編程 2025-04-29
  • Python被稱為膠水語言

    Python作為一種跨平台的解釋性高級語言,最大的特點是被稱為”膠水語言”。 一、簡單易學 Python的語法簡單易學,更加人性化,這使得它成為了初學者的入…

    編程 2025-04-29
  • OpenJudge答案1.6的C語言實現

    本文將從多個方面詳細闡述OpenJudge答案1.6在C語言中的實現方法,幫助初學者更好地學習和理解。 一、需求概述 OpenJudge答案1.6的要求是,輸入兩個整數a和b,輸出…

    編程 2025-04-29
  • Python按位運算符和C語言

    本文將從多個方面詳細闡述Python按位運算符和C語言的相關內容,並給出相應的代碼示例。 一、概述 Python是一種動態的、面向對象的編程語言,其按位運算符是用於按位操作的運算符…

    編程 2025-04-29
  • 如何用Python對數據進行離散化操作

    數據離散化是指將連續的數據轉化為離散的數據,一般是用於數據挖掘和數據分析中,可以幫助我們更好的理解數據,從而更好地進行決策和分析。Python作為一種高效的編程語言,在數據處理和分…

    編程 2025-04-29
  • 如何用Python打印溫度轉換速查表

    本文將從多個方面闡述如何用Python打印溫度轉換速查表,以便於快速進行溫度轉換計算。 一、Python打印溫度轉換速查表的基本知識 在計算機編程領域中,溫度轉換是一個重要的計算。…

    編程 2025-04-29

發表回復

登錄後才能評論