Python のデータ構造とアルゴリズム - 優先度キュー

Python のデータ構造とアルゴリズム - 優先度キュー

[[405132]]

序文

キュー ライブラリは、マルチスレッド プログラミングに適した先入れ先出し (FIFO) データ構造を提供します。これを使用して、プロデューサー スレッドとコンシューマー スレッド間でメッセージやその他のデータを安全に渡すことができます。

呼び出し元のロック処理を行い、複数のスレッドが同じ Queue インスタンスを安全かつ簡単に操作できるようにします。メモリ使用量や処理を制限するために、キューのサイズが制限される場合があります。

基本的な使い方

Queue クラスは、基本的な先入れ先出しコンテナーを実装します。 put() を使用してこのシーケンスの一方の端に要素を追加し、get() を使用してもう一方の端から要素を削除します。具体的なコードは次のとおりです。

  1. インポートキュー
  2.  
  3. q = キュー.キュー()
  4.  
  5. iが範囲(1, 10)内にある場合:
  6. q.put(i)
  7. q.empty()ではない場合:
  8. print(q.get(),終了= " " )

実行後の効果は次のようになります。

ここでは、1 から 10 までを順番にキューに追加します。先入れ先出しの原則により、出てくる順序は追加された順序と同じになります。

LIFO キュー

先入れ先出しキューが存在するため、データ構造には後入れ先出しキューが存在する必要があります。後入れ先出しキューは LifoQueue です。例は次のとおりです。

  1. インポートキュー
  2.  
  3. q = キュー.LifoQueue()
  4.  
  5. iが範囲(1, 10)内にある場合:
  6. q.put(i)
  7. q.empty()ではない場合:
  8. print(q.get(),終了= " " )

実行後の効果は次のようになります。

優先キュー

オペレーティング システムでは、多くの場合、優先度に基づいてタスクを処理します。たとえば、システムの優先度が最も高い場合は、必ず最初にシステム タスクを処理し、次にユーザー タスクを処理します。同様に、キュー ライブラリは、優先キューを処理するための PriorityQueue を提供します。

次に例を示します。

  1. インポートキュー
  2. インポートスレッド
  3.  
  4. クラスジョブ:
  5. def __init__(self, 優先度, desc ):
  6. self.priority = 優先度
  7. 自己.desc = desc  
  8. print( "新しい仕事: " , desc )
  9. 戻る 
  10.  
  11. __eq__(自分、他):
  12. 試す:
  13. self.priority == other.priorityを返す
  14. AttributeErrorを除く:
  15. 実装されていないを返す
  16.  
  17. __lt__(自分、他):
  18. 試す:
  19. self.priority > other.priorityを返す
  20. AttributeErrorを除く:
  21. 実装されていないを返す
  22.  
  23. process_Job(q)を定義します。
  24. 真の場合:
  25. 次のジョブ = q.get()
  26. 印刷( next_job.desc )
  27. タスク完了()
  28.  
  29. q = キュー.優先度キュー()
  30.  
  31. q.put(Job(5, "5つの仕事" ))
  32. q.put(Job(15, "15の仕事" ))
  33. q.put(Job(1, "1つのジョブ" ))
  34.  
  35. 労働者 = [
  36. スレッド化.Thread(ターゲット=process_Job、引数=(q,))、
  37. スレッド化.Thread(ターゲット=process_Job、引数=(q,))、
  38. ]
  39.  
  40. のために 仕事 労働者の場合:
  41. 作業.setDaemon( True )
  42. 作業.開始()
  43.  
  44. q.join ()関数

実行後の効果は次のようになります。

ここでは、値が大きいほど優先度が高くなるようにデフォルト設定されています。15 が最初に実行され、その後に 5 と 1 のタスクが実行されていることがわかります。この例では、複数のスレッドがタスクを処理している場合、get() 中にキュー内の要素の優先度に従ってタスクが処理されることを示しています。

<<:  アラスカ航空は人工知能を活用して時間、燃料、費用を節約

>>:  マッピングドローンは多くの「ファン」を獲得しており、これらの利点は刺激的です

ブログ    
ブログ    

推薦する

...

Adobe がインドのスタートアップ Rephrase.ai を買収、生成 AI 分野で初の買収となる

海外メディアの報道によると、デザインソフトウェアプロバイダーのAdobeは最近、インドの生成AIスタ...

Go 言語アルゴリズムの美しさ - 高度なソート

[[415242]]この記事はWeChatの公開アカウント「roseduanの執筆場所」から転載した...

北京大学と智遠は、大規模モデルが自律的にオープンワールドを探索できるようにするトレーニングフレームワークLLaMA-Riderを提案した。

大規模言語モデルは、強力で普遍的な言語生成および理解機能を備えているため、汎用的なインテリジェントエ...

AIを活用して食材を分析し、より適切な栄養バランスを実現しましょう!

[[396039]]ビッグデータダイジェスト制作出典: Engadget編集:赤道のパンダ人工知能...

OpenAI のセキュリティ脆弱性が明らかに: ChatGPT の制限は一般的でない言語を使用することで簡単に回避可能

10月12日、ブラウン大学のコンピューターサイエンス研究者は、OpenAIのGPT-4セキュリティ設...

AI | 機械知能が人間に代わって行う 5 つのこと

[[322374]]人間の認知能力のあらゆる特性を見てみましょう。まず、Fleishman の 21...

...

人工知能は大きな可能性を秘めているが、大きな責任も抱えている

AI はあらゆるところに存在し、その可能性は計り知れません。しかし、諺にあるように、大いなる力には大...

中国航空工業集団の「ドラゴンネスト」の初飛行は、電力検査のインテリジェント時代の幕開けを告げる

最近、北京市南六環路の北京延尊物流園区付近の安坊線70号塔の下で、中飛Avi Dragon Nest...

...

AIとクラウドワークロードがデータセンターの需要を牽引

JLLの新しいレポートでは、人工知能とエッジコンピューティングの採用が増加するにつれて、データセンタ...

水注入、ピット占拠、ナンセンス:機械学習の学術界における「疑似科学」

[[236693]]ビッグデータダイジェスト制作翻訳者:張秋月、郝貴儿、倪倩、飛、ヴァージル、銭天...

機械学習でサプライチェーンを改善する10の方法

現在、企業は機械学習を使用することで、予測エラー率、需要計画の生産性、コスト削減、納期厳守において ...