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

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

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

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

Q&A

解決済

1回答

643閲覧

双方向リストについて

nagonago424

総合スコア2

C

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

0グッド

0クリップ

投稿2022/11/13 11:12

双方向リストを用いて数値を昇順に格納するプログラムなのですが、以下のようなコードを書いても入力した数値がそのまま格納されてしまいます。
まず、insert_pos関数で格納する場所を返しているのですが、この書き方は大丈夫でしょうか。
またコード中の"1","2"の間にp->num=dを入れてみたのですが、プログラムがうまく動作しませんでした。値を格納するのはポインタの場所が決まらないとできないのでしょうか。どなたかご教示いただけますと幸いです。

#include <stdio.h>
#include <stdlib.h>

struct data_t {
struct data_t *next, *prev;
int num;
};

struct data_t *insert_pos(struct data_t *p, struct data_t *w) {
if (p == NULL) {
} else {
while (w->num > p->num) {
p = p->next;
}
}
return p;
};

struct data_t head;

int main() {
struct data_t *p, *q;
int d, j;
head.prev=&head;
head.next=&head;
for (p=head.next; scanf("%d", &d) != EOF;p=p->next) {
p = (struct data_t *)malloc(sizeof(struct data_t)); "1"
q = insert_pos(head.next, p); "2"
insert(q, p);
p->num = d;
}
}

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

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

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

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

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

jimbe

2022/11/13 12:02 編集

>insert_pos関数で格納する場所を返しているのですが、この書き方は大丈夫でしょうか。 だめでしょう。前の質問 https://teratail.com/questions/pa0aivqc6fd2zj でも(暗に?)指摘されています。 まずは insert _pos がちゃんと狙ったアドレスを返すかどうか、幾つかのパターンでテストするべきです。
setoppu

2022/11/13 11:55

insert()の定義がないようですが? malloc()で確保した構造体の内容で、insert_pos()に渡してnumには何が入っていると思いますか? 双方向リスト(自己参照構造体)で…次の要素(前の要素)がない場合は、ポインタにNULLを入れておくのが慣例ですが、入れていたりしますかね? insert()の実装が不明ですけど。 その上で…for()のp=p->nextは問題なく動くと思いますか?
jimbe

2022/11/13 16:18 編集

>双方向リスト(自己参照構造体)で…次の要素(前の要素)がない場合は、ポインタにNULLを入れておくのが慣例ですが、入れていたりしますかね? >head.prev=&head; >head.next=&head; となっていてヘッダ付きのリングですので NULL にはなりません/してはいけないはずです。 (なので insert_pos の NULL チェックはホトンド意味がありません。)
guest

回答1

0

ベストアンサー

Text

1値を変更する前に、ポインタの場所を決めなければならない。

投稿2022/11/13 14:03

atcoderyellow

総合スコア481

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

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

jimbe

2022/11/13 14:07

わざわざコードのマークダウンに入れる必要は無いと思います。
atcoderyellow

2022/11/13 14:11

この解答はテキストのみを含むことを明示的に示すために、そのマークダウンが用いられている。
jimbe

2022/11/13 15:28 編集

コードのマークダウン自体がコードがあることを明示的に示す為にあるので、使い方が逆でしょう。 「Text」と書かれている個所はプログラム言語名を書く所です。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問