C++でツリーの高さがバランスされているかどうかを確認するプログラム
二分木があるとしましょう。高さがバランスしているかどうかを確認する必要があります。高さのバランスが取れたツリーの場合、ツリー内のすべてのノードについて、左側のサブツリーの高さと右側のサブツリーの高さの絶対差は0または1であることがわかっています。
したがって、入力が次のような場合
その場合、出力はTrueになります
これを解決するには、次の手順に従います-
-
関数dfs()を定義します。これはノードを取ります
-
ノードがnullの場合、-
-
0を返す
-
-
l:=1 + dfs(ノードの左側)
-
r:=1 + dfs(ノードの右側)
-
| l--r|の場合> 1、次に-
-
ret:=false
-
-
lとrの最大値を返す
-
メインの方法から、次のようにします-
-
ret:=true
-
dfs(root)
-
retを返す
理解を深めるために、次の実装を見てみましょう-
例
#include <bits/stdc++.h> using namespace std; class TreeNode { public: int val; TreeNode *left; TreeNode *right; TreeNode(int x) : val(x), left(NULL), right(NULL) {} }; class Solution { public: bool ret; int dfs(TreeNode* node){ if(!node) return 0; int l = 1 + dfs(node->left); int r = 1 + dfs(node->right); if(abs(l - r) > 1) ret = false; return max(l, r); } bool isBalanced(TreeNode* root) { ret = true; dfs(root); return ret; } }; main(){ Solution ob; TreeNode *root = new TreeNode(25); root->left = new TreeNode(19); root->right = new TreeNode(4); root->left->left = new TreeNode(9); root->left->right = new TreeNode(7); cout << (ob.isBalanced(root)); }
入力
TreeNode *root = new TreeNode(25); root->left = new TreeNode(19); root->right = new TreeNode(4); root->left->left = new TreeNode(9); root->left->right = new TreeNode(7);
出力
1
-
特定のツリーグラフが線形であるかどうかをC++で確認します
ここでは、ツリーグラフが線形であるかどうかを確認する方法を説明します。線形ツリーグラフは1行で表すことができます。これが線形ツリーグラフの例であると仮定します。 しかし、これは線形ではありません- グラフが線形であるかどうかを確認するには、2つの条件に従うことができます ノードの数が1の場合、ツリーグラフは線形です ノードの(n – 2)が次数2の場合 例 #include <iostream> #include <vector> #define N 4 using namespace std; class Graph{ p
-
グラフが強く接続されているかどうかをチェックするC++プログラム
有向グラフでは、1つのコンポーネントの頂点の各ペアの間にパスがある場合、コンポーネントは強く接続されていると言われます。 このアルゴリズムを解決するには、まず、DFSアルゴリズムを使用して各頂点の終了時間を取得し、次に転置されたグラフの終了時間を検索します。次に、頂点をトポロジカルソートの降順で並べ替えます。 入力 :グラフの隣接行列。 0 0 1 1 0 1 0 0 0 0 0 1 0 0 0 0 0 0 0 1 0 0 0 0 0 出力 :以下は、与え