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

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

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

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Q&A

解決済

2回答

431閲覧

2分木の高さを求めるためのコードの書き方を教えてください!

a.hamaaaaaaaa

総合スコア12

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

0グッド

0クリップ

投稿2018/06/21 09:14

編集2018/06/22 05:25

今、LeetCodeというサイトでアルゴリズム問題を解いているのですが、
二分木の高さを求める問題に苦戦しています。

以下問題です。

=====================================================================
Given a binary tree, find its maximum depth.

The maximum depth is the number of nodes along the longest path from the root node down to the farthest leaf node.

Note: A leaf is a node with no children.

Example:

Given binary tree [3,9,20,null,null,15,7]

=====================================================================

考え方をおしえていただけたら幸いです!

よろしくお願いします!

以下追記
調べていたら、このような回答を見つけたのですが、
まったくもってコードの仕組みがわからないです。

ruby

1def max_depth(root) 2 root ? 1 + [max_depth(root.left), max_depth(root.right)].max : 0 3end

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

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

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

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

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

guest

回答2

0

ベストアンサー

追記に対してです。

子nodeに対して再帰で深さを取ってきて、大きい方を親に戻り値として返している処理ですね。
深さを見に行った時に、そのnodeが子nodeを持たない時はそれ以上深さを持たないので深さ0として戻り値を返しています。

これを繰り返すと、深さ優先探索で全探索するので一番上のrootに戻ってきた時に大きな深さが戻ってくる仕組みになっています。

投稿2018/07/08 05:23

hiro_n

総合スコア70

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

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

a.hamaaaaaaaa

2018/07/09 07:43

ありがとうございます! たすかりました!
guest

0

幅優先探索かな

[root] => [right,left] => [leftleft,leftright,rightleft,rightright]

こんな感じの再帰組むのが手っ取り早い

投稿2018/06/21 09:29

asm

総合スコア15147

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

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

a.hamaaaaaaaa

2018/06/21 09:48

回答有り難うございます。深度を出したいのですが、ご教示頂いた考え方でいいのでしょうか? 深さ優先探索というのもあるのですが、そちらかなと思いまして。
asm

2018/06/21 10:27

どちらでも、お好みでどうぞ
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問