キューは特別な線形テーブルです。テーブルのフロントエンド (フロントと呼ぶことができます) でのみ削除操作が可能ですが、テーブルのバックエンドでは削除操作のみが許可されます。 、後から呼び出して挿入操作を実行できます。 (推奨学習: PHP ビデオ チュートリアル )
キューはスタックと同じで、操作が制限された線形テーブルです。スタックとの違いは、キューがスタックと異なる点です。は「高度な先出し」の原則に従いますが、スタックは「先入れ後出し」の原則に従います。挿入操作が実行されるキューの最後をキューの末尾と呼び、削除操作が実行されるキューの最後をキューの先頭と呼びます。挿入操作はキューの最後でのみ許可され、削除はキューの最後でのみ許可されます。操作はキューの先頭で許可されます。
キューのデータ要素はキュー要素とも呼ばれ、キューの最後尾に要素を挿入することをエンキュー、キューの先頭にある要素を削除することをデキューといいます。特定の実装参照コード:
<?php /** * php队列算法 * * Create On 2010-6-4 * Author Been * QQ:281443751 * Email:binbin1129@126.com **/ class data { //数据 private $data; public function __construct($data){ $this->data=$data; echo $data.":哥进队了!<br>"; } public function getData(){ return $this->data; } public function __destruct(){ echo $this->data.":哥走了!<br>"; } } class queue{ protected $front;//队头 protected $rear;//队尾 protected $queue=array('0'=>'队尾');//存储队列 protected $maxsize;//最大数 public function __construct($size){ $this->initQ($size); } //初始化队列 private function initQ($size){ $this->front=0; $this->rear=0; $this->maxsize=$size; } //判断队空 public function QIsEmpty(){ return $this->front==$this->rear; } //判断队满 public function QIsFull(){ return ($this->front-$this->rear)==$this->maxsize; } //获取队首数据 public function getFrontDate(){ return $this->queue[$this->front]->getData(); } //入队 public function InQ($data){ if($this->QIsFull())echo $data.":我一来咋就满了!(队满不能入队,请等待!)<br>"; else { $this->front++; for($i=$this->front;$i>$this->rear;$i--){ //echo $data; if($this->queue[$i])unset($this->queue[$i]); $this->queue[$i]=$this->queue[$i-1]; } $this->queue[$this->rear+1]=new data($data); //print_r($this->queue); //echo $this->front; echo '入队成功!<br>'; } } //出队 public function OutQ(){ if($this->QIsEmpty())echo "队空不能出队!<br>"; else{ unset($this->queue[$this->front]); $this->front--; //print_r($this->queue); //echo $this->front; echo "出队成功!<br>"; } } } $q=new queue(3); $q->InQ("小苗"); $q->InQ('马帅'); $q->InQ('溜冰'); $q->InQ('张世佳'); $q->OutQ(); $q->InQ("周瑞晓"); $q->OutQ(); $q->OutQ(); $q->OutQ(); $q->OutQ();
この場合、2 つのクラスがあります:
1 つ目はデータ クラスで、データを格納し、キュー要素を入力するために使用されます。キューとキューからの取り出しの状況;
2 番目の状況はキュー クラスで、キュー要素のキューへの追加およびキューからの取り出し操作に使用されます。
#キューには 4 つの属性が含まれています:
front (キューの先頭) rear (キューの末尾) maxsize (キューの長さ、つまりキュー要素の数) queue (キューに入れられたすべてのキュー要素を格納するオブジェクト) 1.キュー、キューを生成し、パラメーターを渡します。 maxsize 初期化キューとして、キューの後部を 0 に、キューの前部を 0 に設定します。この時点で、キューには要素 0 のみがあり、後部と後部の両方の要素が存在します。それを前に指します。 2. キューに参加するときは、まずキューが満杯かどうかを判断する必要があります (フロント-リア == maxsize)。満杯の場合は挿入は許可されません。満杯でない場合は、挿入が許可されます。許可された。挿入時、フロントがインクリメントされ、キューのすべての要素が 1 つ前方に移動され (新しい要素を挿入するためにキューの末尾位置を残します)、その後、新しいデータ オブジェクトが生成され、キューの末尾位置に挿入されます。列。 3. デキュー時にキューが空かどうか(前 == 後ろ)を判定し、空の場合はデキューできません。空でない場合は、front が指すオブジェクトを削除し、front をデクリメントしてデキューを完了します。実行結果は次のとおりです:
小苗:哥进队了! 入队成功 马帅:哥进队了! 入队成功 溜冰:哥进队了! 入队成功 张世佳:我一来咋就满了!(队满不能入队,请等待!) 小苗:哥走了! 出队成功! 周瑞晓:哥进队了! 入队成功 马帅:哥走了! 出队成功! 溜冰:哥走了! 出队成功! 周瑞晓:哥走了! 出队成功! 队空不能出队! 队空不能出队!
以上がphpにはキューの概念はありますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

この記事では、酸とベースのデータベースモデルを比較し、その特性と適切なユースケースを詳述しています。酸は、財務およびeコマースアプリケーションに適したデータの整合性と一貫性を優先し、ベースは可用性に焦点を当て、

この記事では、コードインジェクションのような脆弱性を防ぐために、PHPファイルのアップロードを確保することについて説明します。ファイルタイプの検証、セキュアストレージ、およびアプリケーションセキュリティを強化するエラー処理に焦点を当てています。

記事では、組み込み関数、ホワイトリストアプローチ、サーバー側の検証などの手法に焦点を当てたセキュリティを強化するためのPHP入力検証のベストプラクティスについて説明します。

この記事では、Token BucketやLeaky BucketなどのアルゴリズムやSymfony/Rate-Limiterなどのライブラリを使用するなど、PHPでAPIレート制限を実装するための戦略について説明します。また、監視、動的に調整されたレートの制限、および手をカバーします

この記事では、パスワードを保護するためにPHPでpassword_hashとpassword_verifyを使用することの利点について説明します。主な議論は、これらの関数が自動塩の生成、強力なハッシュアルゴリズム、およびSecurを通じてパスワード保護を強化するということです

この記事では、PHPおよび緩和戦略におけるOWASPトップ10の脆弱性について説明します。重要な問題には、PHPアプリケーションを監視および保護するための推奨ツールを備えたインジェクション、認証の壊れ、XSSが含まれます。

この記事では、PHPでのXSS攻撃を防ぐための戦略について説明し、入力の消毒、出力エンコード、セキュリティを向上させるライブラリとフレームワークの使用に焦点を当てています。

この記事では、PHPでのインターフェイスと抽象クラスの使用について説明し、それぞれをいつ使用するかに焦点を当てています。インターフェイスは、無関係なクラスや複数の継承に適した、実装なしで契約を定義します。抽象クラスは共通の機能を提供します


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

MinGW - Minimalist GNU for Windows
このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

SublimeText3 中国語版
中国語版、とても使いやすい

EditPlus 中国語クラック版
サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

AtomエディタMac版ダウンロード
最も人気のあるオープンソースエディター

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境
