C ++
 Computer >> コンピューター >  >> プログラミング >> C ++

C++のBSTで指定された合計を持つペアを検索します


このチュートリアルでは、合計が二分探索木の指定された数に等しいペアを見つけるプログラムを作成します。

ペアを見つけるために、ツリーの値を2つの異なるリストに格納します。問題を解決するための手順を見てみましょう。

  • 二分木の構造体ノードを作成します。

  • 二分探索木に新しいノードを挿入する関数を記述します。

    • 二分探索木では、ルートよりも小さい要素はすべて小さく、右は大きくなることを忘れないでください。

  • 2つの空のリストを初期化して、ツリーの左右のノードを保存します。

  • 左または右のノードがNULLになるか、両方のリストが空でなくなるまで、二分探索木を繰り返します。

    • すべての要素を左側のノードリストに格納するループを作成します。

    • すべての要素を適切なノードリストに格納するループを作成します。

    • 各リストから最後のノードを取得します。

    • 2つの値を確認してください。

      • 左側のノードの値が右側のノードの値以上の場合は、ループを解除します。

      • 2つの値の合計が指定された数に等しい場合は、出力してループを中断します。

      • 2つの値の合計が指定された数よりも小さい場合は、左側のリストから最後のノードを削除し、ノードの右側に移動します。

      • 2つの値の合計が指定された数より大きい場合は、右側のリストから最後のノードを削除し、ノードの左側に移動します。

コードを見てみましょう。

#include<bits/stdc++.h>
using namespace std;
struct Node{
   int data;
   Node *left, *right, *root;
   Node(int data) {
      this->data = data;
      left = NULL;
      right = NULL;
      root = NULL;
   }
};
Node* insertNewNode(Node *root, int data){
   if (root == NULL) {
      root = new Node(data);
      return root;
   }
   if (root->data < data) {
      root->right = insertNewNode(root->right, data);
   }
   else if (root->data > data) {
      root->left = insertNewNode(root->left, data);
   }
   return root;
}
void findThePairs(Node *node, int target) {
   vector<Node*> left_side_nodes;
   vector<Node*> right_side_nodes;
   Node *current_left = node;
   Node *current_right = node;
   while (current_left != NULL || current_right != NULL || (left_side_nodes.size() > 0 && right_side_nodes.size() > 0)) {
      while (current_left != NULL) {
         left_side_nodes.push_back(current_left);
         current_left = current_left->left;
      }
      while (current_right != NULL) {
         right_side_nodes.push_back(current_right);
         current_right = current_right->right;
      }
      Node *left_side_node = left_side_nodes[left_side_nodes.size() - 1];
      Node *right_side_node = right_side_nodes[right_side_nodes.size() - 1];
      int left_side_value = left_side_node->data;
      int right_side_value = right_side_node->data;
      if (left_side_value >= right_side_value) {
         break;
      }
      if (left_side_value + right_side_value < target) {
         left_side_nodes.pop_back();
         current_left = left_side_node->right;
      }
      else if (left_side_value + right_side_value > target) {
         right_side_nodes.pop_back();
         current_right = right_side_node->left;
      }
      else {
         cout << left_side_node->data << " " << right_side_node->data << endl;
         break;
      }
   }
}
int main() {
   Node *root = NULL;
   root = insertNewNode(root, 25);
   root = insertNewNode(root, 20);
   root = insertNewNode(root, 30);
   root = insertNewNode(root, 15);
   root = insertNewNode(root, 21);
   root = insertNewNode(root, 19);
   root = insertNewNode(root, 31);
   findThePairs(root, 36);
}

出力

上記のプログラムを実行すると、次の結果が得られます。

15 21

結論

チュートリアルに質問がある場合は、コメントセクションにそのことを記載してください。


  1. C++の平衡二分探索木で与えられた合計を持つペアを見つけます

    平衡二分探索木とターゲット合計があるとすると、合計がターゲット合計に等しいペアであるかどうかをチェックするメソッドを定義する必要があります。この場合。二分探索木は不変であることに注意する必要があります。 したがって、入力が次のような場合 その場合、出力は(9 + 26 =35)になります。 これを解決するには、次の手順に従います- スタックs1、s2を定義する done1:=false、done2:=false val1:=0、val2:=0 curr1:=root、curr2:=root 無限ループ、実行- done1がfalseの場合、do − curr1が

  2. Javaの平衡BSTで指定された合計のペアを検索します

    コンセプト 与えられた平衡二分探索木とターゲットの合計に関して、合計がターゲットの合計に等しいペアがある場合はtrueを返し、そうでない場合はfalseを返す関数を記述します。この場合、予想される時間計算量はO(n)であり、O(Logn)の余分なスペースのみを実装できます。ここでは、二分探索木の変更は許可されていません。バランスBSTの高さは常にO(Logn)であることに注意する必要があります。 例 メソッド ブルートフォースソリューションによると、BSTの各ペアを検討し、合計がXに等しいかどうかを検証します。このソリューションの時間計算量はO(n ^ 2)になります。 ここで