Python-キュー

私たちはサービスを待つ間、日常生活の中で待ち行列に精通しています。キューのデータ構造も、データ要素がキューに配置されている場合と同じ意味です。キューの独自性は、アイテムの追加と削除の方法にあります。アイテムは一方の端で許可されますが、もう一方の端から削除されます。つまり、先入れ先出し法です。キューは、insert()メソッドとpop()メソッドを使用して要素を追加および削除できるPythonリストを使用して実装できます。データ要素は常にキューの最後に追加されるため、これらは挿入されません。

キューへの要素の追加

以下の例では、First-in-First-Outメソッドを実装するキュークラスを作成します。データ要素の追加には、組み込みの挿入メソッドを使用します。

class Queue:

  def __init__(self):
      self.queue = list()

  def addtoq(self,dataval):
# Insert method to add element
      if dataval not in self.queue:
          self.queue.insert(0,dataval)
          return True
      return False

  def size(self):
      return len(self.queue)

TheQueue = Queue()
TheQueue.addtoq("Mon")
TheQueue.addtoq("Tue")
TheQueue.addtoq("Wed")
print(TheQueue.size())

上記のコードを実行すると、次の結果が得られます。

3

キューからの要素の削除

以下の例では、データを挿入し、組み込みのpopメソッドを使用してデータを削除するキュークラスを作成します。

class Queue:

  def __init__(self):
      self.queue = list()

  def addtoq(self,dataval):
# Insert method to add element
      if dataval not in self.queue:
          self.queue.insert(0,dataval)
          return True
      return False
# Pop method to remove element
  def removefromq(self):
      if len(self.queue)>0:
          return self.queue.pop()
      return ("No elements in Queue!")

TheQueue = Queue()
TheQueue.addtoq("Mon")
TheQueue.addtoq("Tue")
TheQueue.addtoq("Wed")
print(TheQueue.removefromq())
print(TheQueue.removefromq())

上記のコードを実行すると、次の結果が得られます。

Mon
Tue