質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
C

C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。

C++

C++はC言語をもとにしてつくられた最もよく使われるマルチパラダイムプログラミング言語の1つです。オブジェクト指向、ジェネリック、命令型など広く対応しており、多目的に使用されています。

Q&A

解決済

3回答

6679閲覧

C言語で入力値以下の素数の最大値を求めたい

tsk1999

総合スコア8

C

C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。

C++

C++はC言語をもとにしてつくられた最もよく使われるマルチパラダイムプログラミング言語の1つです。オブジェクト指向、ジェネリック、命令型など広く対応しており、多目的に使用されています。

0グッド

1クリップ

投稿2020/07/14 17:27

前提・実現したいこと

C言語で、入力値以下(1000以下の入力値n)の素数の最大値を求めて表示したい。

該当のソースコード

#include<stdio.h> int prime(int); int main(void){ int n,i,j; scanf("%d",&n); printf("入力値:%d\n",n); for(i=1000;i>1;i--){ j=prime(i); if(j==2){ break; } } printf("%d",i); return 0; } int prime(const int n){ int i,j; j=0; for(i=2;i<=n;i++){ if(n%i==0){ j++; } } return j; }

試したこと

素数を計算する関数のなかで入力してその入力値をもとに素数の計算をおこなうように考えてみました。

#include<stdio.h> int primeNumber(int); int main(void){ int n,i,j; printf("入力値:%d\n",n); for(i=1000;i>1;i--){ j=primeNumber(i); if(j==2){ break; } } printf("%d",i); return 0; } int primeNumber(const int n){ int i,j; scanf("%d",&n); if(n>=2&&n<=1000){ return n; } j=0; for(i=2;i<=n;i++){ if(n%i==0){ j++; } } return j; }

この場合だと永続的に入力を要求されるようになります。

補足情報(FW/ツールのバージョンなど)

visual studio codeでプログラムしています。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答3

0

ベストアンサー

素数関連の問題はエラトステネスの篩を使えばいいです。

c

1#include <stdbool.h> 2#include <stdio.h> 3#include <stdlib.h> 4#include <string.h> 5 6int primeNumber(const int n) 7{ 8 bool* isprime; 9 if (n < 2) { 10 return -1; 11 } 12 isprime = (bool*)malloc((n + 1) * sizeof(bool)); 13 memset(isprime, true, (n + 1) * sizeof(bool)); 14 15 int res = 2; 16 for (int i = 2; i <= n; i++) { 17 if (isprime[i]) { 18 for (int j = 2 * i; j <= n; j += i) { 19 isprime[j] = false; 20 } 21 res = i; 22 } 23 } 24 free(isprime); 25 return res; 26} 27int main(void) 28{ 29 int n; 30 scanf("%d", &n); 31 printf("入力値:%d\n", n); 32 33 int res = primeNumber(n); 34 if (res == -1) { 35 printf("素数はありません\n"); 36 return 0; 37 } 38 printf("%d\n", res); 39 return 0; 40} 41

投稿2020/07/15 00:44

編集2020/07/15 02:51
Penpen7

総合スコア698

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

tsk1999

2020/07/15 05:45

無事実現できました。エラトステネスの篩のアルゴリズムについての知識皆無だったので勉強になりました。ありがとうございます。
guest

0

n は素数か?
n-1 は素数か?
n-2 は素数か?
:
:
3 は素数か?
2 は素数か?

とループ処理して最初に見つかった素数を表示して処理を終了すればいいので、

c

1 for(i=n;i>1;i--){

というループにして、iが素数か調べて、素数なら表示して処理を終了すればいいのでは?

追記: エラストネスの篩を使った実装例を示しておきます。

c

1#include <stdio.h> 2 3int main(void) { 4 int n; 5 scanf("%d", &n); 6 printf("入力値:%d\n", n); 7 8 int primes[n + 1]; 9 for (int i = 0; i <= n; i++) primes[i] = (i > 3 && i % 2 == 0) ? 0 : i; 10 for (int i = 2; i*i <= n; i++) if (primes[i] != 0) for (int x = i + i; x <= n; x += i) primes[x] = 0; 11 while (n > 0 && primes[n] == 0) n--; 12 printf("%d", n); 13 return 0; 14}

投稿2020/07/14 18:09

編集2020/07/15 01:30
shiracamus

総合スコア5406

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

uyu0531

2021/06/03 11:22 編集

すみません。同じような問題を解いているものです。 for(i=n;i>1;i--){ というループにして、iが素数か調べて、素数なら表示して処理を終了すればいいのでは? とありますが、ここについて詳しく解説いただけないでしょうか。よろしくお願いいたします。
guest

0

for(i=1000;i>1;i--){

for (i = n; i > 1; i--) {

にしたらいいかと思ったらいろいろよくなかった。

c

1#include<stdio.h> 2int prime(int); 3 4int main(void) { 5 int n; 6 scanf("%d", &n); 7 printf("入力値:%d\n", n); 8 9 for (int i = n; i > 1; i--) { 10 if (prime(i) != 0) { 11 printf("%d", i); 12 break; 13 } 14 } 15 return 0; 16} 17 18int prime(int n) { 19 if (n < 2) { 20 return 0; 21 } else if (n == 2) { 22 return 1; 23 } else if (n % 2 == 0) { 24 return 0; 25 } 26 27 int odd = 3; 28 while (odd * odd <= n) { 29 if (n % odd == 0) { 30 return 0; 31 } 32 odd += 2; 33 } 34 return 1; 35}

投稿2020/07/14 18:06

bboydaisuke

総合スコア5275

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問