![](http://oshiete.xgoo.jp/images/v2/pc/qa/question_title.png?8acaa2e)
![](http://oshiete.xgoo.jp/images/v2/common/profile/M/noimageicon_setting_12.png?8acaa2e)
C言語のノードの連結について質問です。
途中までできていて、残りがわからないです。
作ろうとしているプログラムは、ノードpの後にノードq以降のリストを連結する関数を作ろうとしています。
#include<stdio.h>
struct node{
int data;
struct node *next;
};
struct node *head,*tail;
void concat(struct node *p, struct node *q)
{
if(p -> head == NULL) もしpがなにもなかったら
これ以降が思いつきません。
elseではどうしたらいいんでしょうか。
よろしくお願いします。
A 回答 (2件)
- 最新から表示
- 回答順に表示
No.2
- 回答日時:
> if(p -> head == NULL) もしpがなにもなかったら
↑struct node に head というメンバーはありませんよ。
> ノードpの後にノードq以降のリストを連結する関数
↑不明確です。
変数 head と tail がそれぞれ構造体 node の先頭と末尾を示しいるとして、ノードp は head が示すリストへ連結されている一つのノードであり、ノードq はまだ head が示すリストへ連結されていないノードリストであると仮定した場合、
struct node * n;
for (n = q; n != NULL; n = n->next)
{
if (n->next == NULL)
break;
}
if (p->next == NULL) /* ノードp は末尾である p == head もしくは p == tail でも確認可 */
tail = n; /* tail へノードリストq の末尾ノードを代入 */
else /* 中間ノード */
n->next = p->next; /* ノードリストq の末尾ノードの next へノードp の次のノードを代入 */
p->next = q; /* ノードp の next へ q を代入 */
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- C言語・C++・C# c言語の問題です 3 2023/01/10 16:15
- 大学・短大 C言語線形リストの問題です 3 2022/12/22 00:45
- C言語・C++・C# leetcode21 1 2022/04/21 11:53
- C言語・C++・C# バイナリファイルをコピーするのにかかる時間を測りたいのですが実行するとFatel error:gli 2 2022/11/03 01:10
- C言語・C++・C# プログラミング c言語 4 2023/03/07 01:05
- C言語・C++・C# leetcode 155 minstack 1 2022/05/07 16:43
- C言語・C++・C# 未解決の外部シンボル _printfが関数_mainで参照されました 1 2022/09/18 15:28
- C言語・C++・C# C言語 leetcode21 Merge Two Sorted Lists 2 2022/04/24 19:35
- C言語・C++・C# プログラムが書けません。 4 2023/01/22 22:57
- C言語・C++・C# C言語初心者 構造体 課題について 2 2023/03/10 19:48
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
10進数からN進数に変換するプロ...
-
c言語
-
c言語
-
複素関数はどこはあんまりやら...
-
プログラム言語について c言語...
-
バッチファイルで以下のような...
-
C言語初心者です、、、お助けく...
-
C言語階乗の総和を求める
-
c言語のリダイレクトによる円...
-
右ビットシフト
-
C言語をコンパイルするとコンピ...
-
gccを行ってもexeファイルが生...
-
C言語の関数と配列に関する質問
-
C++でデスクトップGUIアプリ開...
-
C言語 バッファについて。
-
大量のデータを読み込んで表示...
-
UnityInputSystemによるtouch入...
-
C++のcase文の書き方
-
CPUが16bitでも32bitOSでコンパ...
-
プログラミングでArduinoのc++...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
CPUの考え方を教えてください ...
-
昔Winnyってありましたけど、あ...
-
SNMP リンクダウンとノードダ...
-
ルート要素ノードが2個ある場合?
-
あるノードリストに、特定の名...
-
同じタグ名の項目取得
-
コンテキストメニュークリック...
-
ノードとは
-
XML文書の指定した属性値を持つ...
-
ツリービューのノードをダブル...
-
2分探索木の高さを求めるプロ...
-
C# TreeView 効率良いノード追...
-
VB6.0でDOMを使用して...
-
スケールフリーネットワークをC...
-
複数のマックPCによる数値計算...
-
C#でtreeviewの指定ノードを選...
-
TreeViewに重複する値をセット
-
ツリービューの使い方が・・・
-
各ノードの行数取得
-
TreeViewの再表示のちらつきを...
おすすめ情報