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

Pythonで可能になるまで、配列内の要素のペアワイズ差を追加して、勝者を見つけます


正の整数の配列Aがあり、要素が一意であるとすると、2人のプレーヤーPとQがゲームをプレイしています。各移動で、1人のプレーヤーが配列から2つの数字aとbを選び、| a –b|の場合その後、プレーヤーはこの番号を配列に追加します。プレイヤーが移動できない場合、ゲームに負けます。プレーヤーPが常にゲームを開始する場合は、ゲームの勝者を見つける必要があります。

したがって、入力がA =[8,9,10]の場合、出力はPになります。

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

  • n:=arrのサイズ

  • g:=arr [0]、max_val:=arr [0]

  • 1からnの範囲のiの場合、実行します

    • g:=gcd(g、arr [i])

    • max_val:=max_valの最大値、arr [i]

  • 合計:=(max_val / g)-n

  • 合計が奇数の場合、

    • 'P'を返す

  • 'Q'を返す

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

from math import gcd
def who_is_the_winner(arr) :
   n = len(arr)
   g = arr[0]
   max_val = arr[0]
   for i in range(1, n) :
      g = gcd(g, arr[i])
      max_val = max(max_val, arr[i])
   total = (max_val / g) - n
   if (total % 2 == 1) :
      return 'P'
   return 'Q'

arr = [8,9,10]
print(who_is_the_winner(arr))

入力

[8,9,10]

出力

P

  1. 配列内の最大の要素を見つけるPythonプログラム

    この記事では、以下に示す問題ステートメントの解決策について学習します。 問題の説明 −配列が与えられたので、配列の最大要素を計算する必要があります。 ここでは、ループ全体をトラバースして最大の要素を計算し、要素を取得するブルートフォースアプローチを使用します。 以下の実装を観察できます。 例 # largest function def largest(arr,n):    #maximum element    max = arr[0]    # traverse the whole loop    for

  2. 配列の合計を見つけるPythonプログラム

    この記事では、特定の問題ステートメントを解決するための解決策とアプローチについて学習します。 問題の説明 入力として配列が与えられた場合、与えられた配列の合計を計算する必要があります。 ここでは、ブルートフォースアプローチに従うことができます。つまり、リストをトラバースし、各要素を空の合計変数に追加します。最後に、合計の値を表示します。 以下で説明するように、組み込みの合計関数を使用して別のアプローチを実行することもできます。 例 # main arr = [1,2,3,4,5] ans = sum(arr,n) print ('Sum of the array is '