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

Pythonで5で割り切れるバイナリプレフィックス


0と1の配列Aがあるとすると、N[i]は2進数として解釈されるインデックスA[0]からA[i]までのi番目のサブ配列であると考えます。ブール値の回答のリストを見つける必要があります。ここで、answer [i]は、N[i]が5で割り切れる場合にのみtrueになります。

したがって、入力が[0,1,1,1,1,1]の場合、出力は[true、false、false、false、true、false]

になります。

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

  • 長さ:=Aのサイズ
  • ans:=サイズの長さの配列を作成し、falseで埋めます
  • number:=Aの各要素を連結したバイナリ値
  • 0から長さの範囲のiについては、
    • 番号mod5が0と同じ場合、
      • ans [length-i-1]:=True
    • 番号:=番号/ 2
  • 回答を返す

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

class Solution:
   def prefixesDivBy5(self, A):
      length=len(A)
      ans=[False]*length
      number=int("".join(map(str,A)),2)
      for i in range(length):
         if number%5==0:
            ans[length-i-1]=True
            number=number>>1
      return ans
ob = Solution()
print(ob.prefixesDivBy5([0,1,1,1,1,1]))

入力

[0,1,1,1,1,1]

出力

[True, False, False, False, True, False]

  1. Pythonでの二分木の直径

    二分木があるとしましょう。木の直径の長さを計算する必要があります。二分木の直径は、実際には、ツリー内の任意の2つのノード間の最長パスの長さです。このパスは必ずしもルートを通過する必要はありません。したがって、ツリーが以下のようになっている場合、パスの長さ[4,2,1,3]または[5,2,1,3]は3であるため、直径は3になります。 これを解決するには、次の手順に従います- dfsを使用して直径を見つけ、答えを設定します:=0 ルートdfs(root)を使用してdfs関数を呼び出します dfsは以下のdfs(node)のように機能します ノードが存在しない場合は、0を返します 左

  2. Pythonで二分木を反転する

    二分木があるとします。私たちの仕事は、逆二分木を作成することです。したがって、ツリーが以下のようになっている場合- 反転したツリーは次のようになります これを解決するために、再帰的アプローチを使用します ルートがnullの場合は、戻ります 左右のポインタを入れ替える 左のサブツリーと右のサブツリーを再帰的に解決します 例(Python) 理解を深めるために、次の実装を見てみましょう- class TreeNode:    def __init__(self, data, left = None, right = None):