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

Pythonで配列の要素を並べ替えるのに必要なシャッフルの予想数を見つけるプログラム


要素numsのセットがあるとします。降順ではない順序で並べ替える必要があります。ただし、並べ替えの手法はランダム化されています。配列がソートされているかどうかをチェックします。ソートされていない場合は、ランダムにシャッフルして再度チェックします。すべての要素がソートされるまで、このプロセスを続けます。この場合、それらをソートするために必要なシャッフルの予想数を見つける必要があります。小数点以下6桁までの回答を表示してください。

したがって、入力がnums =[5,2,7]のような場合、3つの順列が可能であるため、出力は6になり、確率は1/3になります

  • i =1回の反復でソートされた配列を取得する場合、1/3かかります
  • i =2回の反復でソートされた配列を取得する場合、(2/3)*(1/3)が必要になります

i番目の反復回数でソートされた配列を取得する場合、(2/3)^(i-1)*(1/3)

が必要になります。

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

  • numsがソートされている場合、
    • 0を返す
  • それ以外の場合、
    • m:=最初は空の新しい辞書
    • numsの各iについて、
      • iがmに存在する場合、
        • m [i]:=m [i] + 1
      • それ以外の場合、
        • m [i]:=1
    • num:=1
    • mの各キーiについて、実行します
      • num:=num * factorial(m [i])
    • den:=階乗(数値のサイズ)
    • return(den / num)および小数点以下6桁までの四捨五入

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

from math import factorial
def solve(nums):
   if nums == sorted(nums):
      return 0
   else:
      m={}
      for i in nums:
         if i in m:
            m[i]+=1
         else:
            m[i]=1
      num=1
      for i in m:
         num *= factorial(m[i])

      den=factorial(len(nums))
      return round((den/num),6)

nums = [5,2,7]
print(solve(nums))

入力

[5,2,7]

出力

6.0

  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 '