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

Pythonで指定されたリストのすべての乗客をピックアップおよびドロップできるかどうかを確認するプログラム


[start_x、end_x、num_passengers]を含む各行にrequested_tripsという行列があり、容量値もあるとします。これで、要求された各旅行では、start_xでnum_passengersの乗客を迎えに行き、end_xで降ろすように求められます。また、指定された容量の車があり、位置x =0から開始します。すべての乗客を乗せたいので、右側にしか移動できません。全員を乗降できるかどうかを確認する必要があります。

したがって、入力がトリップ=[[1、25、2]、[3、4、3]、[5、12、3]]容量=6のような場合、出力はTrueになります

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

  • イベント:=新しいリスト

  • 旅行の各セット(sx、ex、np)について、実行します

    • イベントの最後にペア(sx、np)を挿入します

    • イベントの最後にペア(例、-np)を挿入します

  • キャリング:=0

  • イベントのリスト(ソートされた順序)の各ペア(loc、delta)について、実行します

    • キャリング:=キャリング+デルタ

    • >容量を運ぶ場合は、

      • Falseを返す

  • Trueを返す

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

class Solution:
   def solve(self, trips, capacity):
      events = []
      for sx, ex, np in trips:
         events.append((sx, np))
         events.append((ex, -np))
      carrying = 0
      for loc, delta in sorted(events):
         carrying += delta
         if carrying > capacity:
            return False
      return True
ob = Solution()
trips = [
   [1, 25, 2],
   [3, 4, 3],
   [5, 12, 3]
]
capacity = 6
print(ob.solve(trips, capacity))

入力

trips = [
[1, 25, 2],
[3, 4, 3],
[5, 12, 3] ]
capacity = 6

出力

True

  1. 与えられたツリーがPythonで対称ツリーであるかどうかをチェックするプログラム

    二分木が1つあるとします。ツリーが対称ツリーであるかどうかを確認する必要があります。鏡像を撮ったときに同じである場合、木は対称であると言われます。これらの2つのツリーから、最初のツリーは対称ですが、2番目のツリーは対称ではありません。 これを解決するために、次の手順に従います。 次の手順を再帰的に呼び出します。関数はsolve(root、root)になります node1とnode2が空の場合、trueを返します node1またはnode2のいずれかが空の場合、falseを返します node1.val =node2.valおよびsolve(node1.lef

  2. 与えられたグラフがPythonで2部グラフであるかどうかをチェックするプログラム

    無向グラフが1つあるとすると、グラフが2部グラフであるかどうかを確認する必要があります。グラフのすべてのエッジ{u、v}がAに1つのノードuを持ち、Bに別のノードvを持つように、グラフのノードを2つのセットAとBに分割できる場合、グラフは2部グラフであることがわかります。 したがって、入力が次のような場合 次に、出力はTrueになり、[0,4]はセットAにあり、[1,2,3]はセットBにあり、すべてのエッジはAからAまたはBからBではなく、AからBまたはBからAになります。 。 これを解決するために、次の手順に従います- 関数dfs()を定義します。これはソースを取ります