
以下のソースコードを用いて二分木を生成して、それをトラバーサルすると
昇順に表示されますが!
これを、用いて全ての節の子を(左の子と右の子)を交換する。
関数定義
void ReverseTree( struct BTREE *ptr);
を再帰的呼び出しによって実現してのですが!
どう考えればよいのでしょうか?
さらに、2分木の生成後に入力した整数値がリスト中にあるかどうかを
判定し、(存在すれば1、存在しなければ、0を関数値とする)
関数定義 int ExistTest(struct BTREE *ptr, searchdata);
を作成し動作を確認したいのですが!
ご教授して下さい。お願いします.
No.2ベストアンサー
- 回答日時:
「再帰だ」ってるのに、あほうですね、私。
枝の処理を忘れてました。それを直せたのだから、検索も簡単でしょう。
TraverseTree() が全てのノードを処理しているのに対し、検索はひとつでも
見つかれば、1を返せばよいのですから。
(1) 自分がその値であるか? そうなら、1を返しておしまい
(2) 無ければ、左にあるか? あれば、1を返しておしまい
(3) 無ければ、右にあるか? あれば、1を返しておしまい
(4) どこにもないので、0を返す
蛇足かもしれませんが、
> } else if (ExistTest(ptr->left, searchdata)) {
と書いたのは
} else if (ExistTest(ptr->left, searchdata) != 0) {
と全く同じことです。
No.1
- 回答日時:
TraverseTree() をじっと見れば、さほど難しくないと思うのだけどなあ。
> 全ての節の子を(左の子と右の子)を交換する。
void ReverseTree(struct BTREE *ptr)
{
if (ptr == NULL) {
return;
} else {
struct BTREE* tmp;
tmp = ptr->left;
ptr->left = ptr->right;
ptr->right = tmp;
}
}
> 2分木の生成後に入力した整数値がリスト中にあるかどうかを
int ExistTest(struct BTREE *ptr, int searchdata)
{
if (ptr == NULL) {
return 0;
} else {
if (ptr->data == searchdata) {
return 1;
} else if (ExistTest(ptr->left, searchdata)) {
return 1;
} else if (ExistTest(ptr->right, searchdata)) {
return 1;
} else {
return 0;
}
}
}
# コンパイルや動作確認をしたわけではないので、自信無しです
この回答への補足
void ReverseTree (struct BTREE *ptr)
{
struct BTREE *workp;
if(ptr == NULL){
return;
}else{
workp = ptr->left;
ptr->left = ptr->right;
ptr->right = workp;
ReverseTree (ptr->left);
ReverseTree (ptr->right);
}
}
入れ替えとトラバーサルを行えばできました。
ありがとうございます。
検索は、奮闘中です.
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
main.c:7:43: warning: implici...
-
【#define】 defineで定義した...
-
int main の前のint add(int a,...
-
相互参照するクラス、俺こんな...
-
C++のfor文について
-
int void (main)の意味・・・
-
VC6でlong longでエラー?
-
DWORDの実際の型は何でしょうか
-
構造体の要素すべてに対する四...
-
GCCで暗黙の型変換の警告を出し...
-
visualstudio C# テキストボッ...
-
intとINTの違いは?
-
変数の型を定義しなかった場合...
-
ハンドルされていない例外が発...
-
LNK2019: 未解決の外部シンボル...
-
C++でboolにintの値を代入する...
-
「Aに対するBの割合」と「Aに対...
-
Aの値からBの値を除するとは??
-
2÷3などの余りについて
-
10個出力で改行したいのですが...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
main.c:7:43: warning: implici...
-
DWORDの実際の型は何でしょうか
-
long型の定数の末尾にLを付ける...
-
visualstudio C# テキストボッ...
-
2重定義って??
-
C++のfor文について
-
C++でboolにintの値を代入する...
-
構造体の要素すべてに対する四...
-
変数の型を定義しなかった場合...
-
C言語のコンパイルエラー
-
プログラムの中で別のmainを呼...
-
typedef enumの使い方を教えて...
-
intとINTの違いは?
-
構造体の宣言でエラーが出ます。
-
ハンドルされていない例外が発...
-
【#define】 defineで定義した...
-
enumについて
-
GCCで暗黙の型変換の警告を出し...
-
C言語 宣言した変数になにも代...
-
void func( void )について
おすすめ情報