C++の特定のノードのサブツリー内のすべてのノードのXOR
この問題では、nツリーが与えられ、ツリーのノードであるクエリがいくつかあります。私たちのタスクは、指定されたノードによって形成されたサブツリーのすべてのノードのXORを出力することです。
問題を理解するために例を見てみましょう
クエリ − {1、6、5}
出力 −
0 0 5
説明 −
1^6^3^2^4^7^5 6^2^4 5
この問題を解決するために、ツリーを1回トラバースして保存することにより、サブツリーのすべてのノードのxorを計算します。ここで、子ノードの場合はサブツリーのすべてのノードのxorを計算し、次に指定されたすべてのサブツリーを計算します。結果を保存すると時間を節約できます。
例
ソリューションの実装を示すプログラム
#include <bits/stdc++.h> using namespace std; vector<vector<int> > graph; vector<int> values, xorValues; int computeXorValues(int i, int prev){ int x = values[i]; for (int j = 0; j < graph[i].size(); j++) if (graph[i][j] != prev) { x ^= computeXorValues(graph[i][j], i); } xorValues[i] = x; return x; } int solveQuerry(int u){ return xorValues[u]; } int main(){ int n = 7; graph.resize(n); xorValues.resize(n); graph[0].push_back(1); graph[0].push_back(2); graph[1].push_back(3); graph[1].push_back(4); graph[2].push_back(5); graph[2].push_back(6); values.push_back(1); values.push_back(2); values.push_back(3); values.push_back(4); values.push_back(5); values.push_back(6); values.push_back(7); computeXorValues(0, -1); int queries[] = { 0, 2, 4, 6 }; int q = sizeof(queries) / sizeof(queries[0]); for (int i = 0; i < q; i++) cout<<"Solution for querry "<<(i+1)<<": "<<solveQuerry(queries[i])<<endl; return 0; }
出力
Solution for querry 1: 0 Solution for querry 2: 2 Solution for querry 3: 5 Solution for querry 4: 7
-
C++で特定のノードから距離kにあるすべてのノードを出力します
この問題では、二分木、ターゲットノード、整数Kが与えられます。ターゲットノードから距離Kにあるツリーのすべてのノードを印刷する必要があります。 。 二分木 は、各ノードに最大2つのノード(1つまたは2つ/なし)を持つ特別なツリーです。 問題を理解するために例を見てみましょう K =2 ターゲットノード:9 出力 − 5 1 3. 説明 − 距離は、ノードの上位、下位、または同じレベルで取得できます。したがって、それに応じてノードを返します。 この問題を解決するには、ターゲットノードからK距離離れたノードのタイプを理解する必要があります。 上記の試験から、k個の離
-
C++で与えられた完全な二分木のすべてのノードの合計を見つけます
完全な二分木のレベル数を表す正の整数Lがあるとします。この完全な二分木のリーフノードには、1からnまでの番号が付けられています。ここで、nはリーフノードの数です。親ノードは子の合計です。私たちの仕事は、この完璧な二分木のすべてのノードの合計を出力するプログラムを書くことです。したがって、ツリーが以下のようになっている場合- したがって、合計は30です。 よく見ると、すべてのノードの合計を見つける必要があります。リーフノードは1からnまでの値を保持しているため、式n(n + 1)/2を使用してリーフノードの合計を取得できます。これは完全な二分木であるため、各レベルの合計は同じになります