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

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

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

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

Q&A

解決済

1回答

964閲覧

C言語 線形リストに求めた素数を保存する

y_yy

総合スコア7

C

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

0グッド

0クリップ

投稿2021/07/19 11:34

前提・実現したいこと

C言語始めたてなので質問が変だったらごめんなさい。
以下のプログラムのstruct node *node_read_multiple()とis_prime()を組み合わせてstruct node *node_read_multiple()にある線形リストにis_prime()で求めた素数を保存するということをしたいです。どのようにいじれば解決するのか簡単にアドバイスだけでもいただけると幸いです。

C

1 2 3#include<stdio.h> 4#include<stdlib.h> 5 6struct node{ 7 struct node *next; 8 int val; 9}; 10 11struct node *node_read_multiple() 12{ 13 struct node *p=malloc(sizeof *p); 14 if(p){ 15 if(scanf("%d",&p->val)==1){ 16 p->next=node_read_multiple(); 17 } 18 else{ 19 free(p); 20 return NULL; 21 } 22 } 23 else 24 return NULL; 25} 26 27 28 29void node_free_multiple(struct node*p) 30{ 31 while(p){ 32 struct node *const next =p->next; 33 free(p); 34 p=next; 35 } 36} 37 38void node_print_multiple(const struct node *p) 39{ 40 for(;p;p=p->next)printf("%d",p->val); 41} 42 43 44 45int main() 46{ 47 struct node *first=node_read_multiple(); 48 node_print_multiple(first); 49 node_free_multiple(first); 50}

is_prime

C

1#include <stdio.h> 2 3int main() 4{ 5 int i,k; 6 int a; 7 int n = 100; 8 9 for (i = 2; i < n; i++) 10 { 11 a = 0; 12 for (k = 2; k < i; k++) 13 { 14 if (i % k == 0) 15 a = a + 1; 16 } 17 18 if (a == 0) printf("%d ", k); 19 } 20 21 printf("\n"); 22 23 return 0; 24} 25

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

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

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

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

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

BeatStar

2021/07/19 11:50

本当にご自分でやったのなら後は合わせればいいのでは? 質問の最後のコードでの「素数を割り出す」部分の変数にセットしている部分を、 「リストに追加する」のやつに切り替えればいいはずです。
jimbe

2021/07/19 16:11 編集

組み合わせて動いても結果の表示は変わらないと思うのですが…間にスペースが無いくらいでしょうか。 リストに保存して(さらに)何かをするのではなく、二つを組み合わせたコードが欲しいということでしょうか。
guest

回答1

0

ベストアンサー

node_read_multiple は、strcut node * を返すはずなのに、
scanf でデータが読めた時は、何も返していません。
だから、実行してデータを入力し終わっても何も表示されません。
修正してください。

is_prime という関数はありません。
n未満の素数を求めるプログラムがあるだけです。
これを次のように変更します。

C

1int get_prime(void) 2{ 3 static int i = 2; 4 const int n = 100; 5 int k, a; 6 while (i < n) { 7 a = 0; 8 for (k = 2; k < i; k++) 9 if (i % k == 0) a++; 10 i++; 11 if (a == 0) return k; 12 } 13 return 0; 14}

そして、node_read_multiple の中の scanf によりデータの読み込みを
get_prime によるデータの取得に置き換えるとよいでしょう。

投稿2021/07/19 16:04

編集2021/07/20 04:09
kazuma-s

総合スコア8224

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

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

y_yy

2021/07/20 04:28

ありがとうございます!試してみます!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問