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

Pythonでカット間隔と交差しない間隔を見つけるプログラム


ソートされてばらばらの間隔リストと、間隔を表す別のリストカットがあるとします。カット間隔と交差する間隔のすべての部分を削除し、新しいリストを返す必要があります。

したがって、入力がintervals =[[2、11]、[13、31]、[41、61]] cut =[8、46]のような場合、出力は[[2、8]、[46]になります。 、61]]

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

  • cut_start、cut_end:=cut
  • ans:=新しいリスト
  • 開始ごとに、間隔を置いて終了し、
    • cut_startとstartの最大値
    • 開始
    • 間隔[start、cut_start]をansに挿入します
  • end> cut_endの場合、
    • 間隔[cut_end、end]をansに挿入します
  • それ以外の場合
  • 回答を返す
  • 理解を深めるために、次の実装を見てみましょう-

    class Solution:
       def solve(self, intervals, cut):
       cut_start, cut_end = cut
       ans = []
       for start, end in intervals:
          if max(cut_start, start) < min(end, cut_end):
             if start < cut_start:
                ans.append([start, cut_start])
                if end > cut_end:
                   ans.append([cut_end, end])
             else:
                ans.append([start, end])
          return ans
    ob = Solution()
    intervals = [[2, 11],[13, 31],[41, 61]] cut = [8, 46]
    print(ob.solve(intervals, cut))

    入力

    [[2, 11],[13, 31],[41, 61]], [8, 46]

    出力

    [[2, 8], [46, 61]]

    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 '