Featured image of post 素数を生成するC言語コード

素数を生成するC言語コード

以下は、指定された範囲内の素数を生成するシンプルなC言語のコードです。この例では、1からnまでの素数を列挙します。

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
#include <stdio.h>
#include <stdbool.h>

bool isPrime(int num) {
    if (num <= 1) return false;
    if (num <= 3) return true;
    if (num % 2 == 0 || num % 3 == 0) return false;
    
    for (int i = 5; i * i <= num; i += 6) {
        if (num % i == 0 || num % (i + 2) == 0) return false;
    }
    return true;
}

void printPrimes(int n) {
    printf("2 ");
    for (int i = 3; i <= n; i += 2) {
        if (isPrime(i)) {
            printf("%d ", i);
        }
    }
    printf("\n");
}

int main() {
    int n;
    printf("素数を生成する範囲の最大値を入力してください: ");
    scanf("%d", &n);
    printf("1から%dまでの素数は以下の通りです:\n", n);
    printPrimes(n);
    return 0;
}

このコードは以下のように動作します:

  1. isPrime関数: 与えられた数が素数かどうかを判定します。効率を考慮して、2と3で割り切れるかどうかを最初にチェックし、その後6の倍数でチェックを進めます。
  2. printPrimes関数: 指定された範囲内の素数を出力します。2は最初に出力し、その後奇数だけをチェックします。
  3. main関数: ユーザーから範囲の最大値を入力してもらい、その範囲内の素数を出力します。

このコードをコンパイルして実行すると、指定された範囲内の素数が表示されます。

comments powered by Disqus
Hugo で構築されています。
テーマ StackJimmy によって設計されています。