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
- 番号mod5が0と同じ場合、
- 回答を返す
理解を深めるために、次の実装を見てみましょう-
例
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]
-
Pythonでの二分木の直径
二分木があるとしましょう。木の直径の長さを計算する必要があります。二分木の直径は、実際には、ツリー内の任意の2つのノード間の最長パスの長さです。このパスは必ずしもルートを通過する必要はありません。したがって、ツリーが以下のようになっている場合、パスの長さ[4,2,1,3]または[5,2,1,3]は3であるため、直径は3になります。 これを解決するには、次の手順に従います- dfsを使用して直径を見つけ、答えを設定します:=0 ルートdfs(root)を使用してdfs関数を呼び出します dfsは以下のdfs(node)のように機能します ノードが存在しない場合は、0を返します 左
-
Pythonで二分木を反転する
二分木があるとします。私たちの仕事は、逆二分木を作成することです。したがって、ツリーが以下のようになっている場合- 反転したツリーは次のようになります これを解決するために、再帰的アプローチを使用します ルートがnullの場合は、戻ります 左右のポインタを入れ替える 左のサブツリーと右のサブツリーを再帰的に解決します 例(Python) 理解を深めるために、次の実装を見てみましょう- class TreeNode: def __init__(self, data, left = None, right = None):