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

Pythonで合計が偶数の最長パスの長さを見つけるプログラム


二分木があるとします。合計が偶数である最長のパスの長さを見つける必要があります。

したがって、入力が画像のような場合、パスは[5、2、4、8、5]、合計=24(偶数)のようになるため、出力は5になります。

これを解決するには、次の手順に従います-

  • 関数dfs()を定義します。これはノードを取ります
  • ノードがnullの場合、
    • ペアを返す(0、-inf)
  • (left_0、left_1):=dfs(ノードの左側)
  • (right_0、right_1):=dfs(ノードの右側)
  • ノードの値が奇数の場合、
    • ans:=ansの最大値、(left_1 + right_0 + 1)および(left_0 + right_1 + 1)
    • ペアを返します(最大(left_1 + 1)、(right_1 + 1)、0)、最大(left_0 + 1)、(right_0 + 1))
  • それ以外の場合、
    • ans:=ansの最大値、(left_0 + right_0 + 1)および(left_1 + right_1 + 1)
    • ペアを返します(最大(left_0 + 1)、(right_0 + 1)、0)、最大(left_1 + 1)、(right_1 + 1))
  • メインの方法から次のようにします-
  • ans:=0
  • dfs(root)
  • 回答を返す

例(Python)

理解を深めるために、次の実装を見てみましょう-

class TreeNode:
   def __init__(self, data, left = None, right = None):
      self.val = data
      self.left = left
      self.right = right
class Solution:
   def solve(self, root):
      def dfs(node):
         if not node:
            return 0, float("-inf")
         left_0, left_1 = dfs(node.left)
         right_0, right_1 = dfs(node.right)
         if node.val & 1:
            self.ans = max(self.ans, left_1 + right_0 + 1, left_0 + right_1 + 1)
            return max(left_1 + 1, right_1 + 1, 0), max(left_0 + 1, right_0 + 1)
         else:
            self.ans = max(self.ans, left_0 + right_0 + 1, left_1 + right_1 + 1)
            return max(left_0 + 1, right_0 + 1, 0), max(left_1 + 1, right_1 + 1)
   self.ans = 0
   dfs(root)
   return self.ans
ob = Solution()
root = TreeNode(2)
root.left = TreeNode(5)
root.right = TreeNode(4)
root.right.left = TreeNode(8)
root.right.right = TreeNode(2)
root.right.left.left = TreeNode(5)
print(ob.solve(root))

入力

root = TreeNode(2)
root.left = TreeNode(5)
root.right = TreeNode(4)
root.right.left = TreeNode(8)
root.right.right = TreeNode(2)
root.right.left.left = TreeNode(5)

出力

5

  1. Pythonで二分木の最長の偶数値パスを見つけるプログラム

    二分木があるとすると、ツリー内の任意の2つのノード間の偶数の値で構成される最長のパスを見つける必要があります。 したがって、入力が次のような場合 最長のパスが[10、2、4、8、6]であるため、出力は5になります。 これを解決するには、次の手順に従います- ans:=0 関数find()を定義します。これはノードを取ります ノードがnullの場合、 戻り値(-1、-1) leftCnt:=find(ノードの左側)の戻り値の最大値+ 1 rightCnt:=find(ノードの右側)の戻り値の最大値+ 1 ノードの値が偶数の場合、

  2. Pythonプログラムで数の偶数因子の合計を見つける

    この記事では、以下に示す問題ステートメントの解決策について学習します。 問題の説明 −数値が与えられているので、数値のすべての偶数因子の合計を表示する必要があります。 アプローチ 数値が奇数かどうかを確認し、偶数の因子がないため、0を返します。 数が偶数の場合、計算を実行します。 20を除く他のすべての項は、偶数の因数の合計を生成するために乗算されます。 偶数因子のすべての奇数を削除するために、1である20を無視します。このステップの後、偶数因子のみを取得しました。 2は私たちが利用できる唯一の素数であることに注意してください。 次に、以下の実装を見てみましょう- 例 # math