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

Pythonを使用してnのk番目の因子を見つけるプログラム


2つの正の値nとkがあるとします。ここで、nのすべての因子のリストが昇順でソートされていると考えて、このリストでk番目の因子を見つける必要があります。 k未満の因子がある場合は、-1を返します。

したがって、入力がn =28 k =4の場合、28の因数は[1,2,4,7,14,28]であり、4番目の因数は7であるため、出力は7になります。

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

  • kが1と同じ場合、

    • 1を返す

  • cand:=1つの要素を持つリスト[1]

  • 2から1の範囲のi+(nの平方根)のフロアの場合、実行

    • n mod iが0と同じ場合、

      • candの最後にiを挿入します

    • m:=カンドのサイズ

  • k> 2 * mまたは(kは2 *mおよびn=(カンドの最後の要素)^ 2と同じ)

    の場合
    • -1を返す

  • k <=mの場合、

    • cand [k-1]

      を返す
  • factor:=cand [2 * m --k]

  • n/factorの商を返す

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

from math import floor
def solve(n ,k):
   if k == 1:
      return 1
   cand = [1]
   for i in range(2, 1+floor(pow(n, 0.5))):
      if n%i == 0:
         cand.append(i)
      m = len(cand)
      if k > 2*m or (k == 2*m and n == cand[-1]**2):
         return -1
      if k <= m:
         return cand[k-1]
      factor = cand[2*m - k]
      return n//factor
n = 28
k = 4
print(solve(n ,k))

入力

28, 4

出力

7

  1. 行列の転置を見つけるPythonプログラム

    この記事では、特定の問題ステートメントを解決するための解決策とアプローチについて学習します。 問題の説明 行列が与えられた場合、転置を同じ行列に格納して表示する必要があります。 行列の転置は、行を列に、列を行に変更することで得られます。つまり、A行列の転置はA[i][j]をA[j][i]に変更することで得られます。 以下に示す実装を見てみましょう- 例 N = 4 def transpose(A):    for i in range(N):       for j in range(i+1, N):     &nbs

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

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