PHP再帰アルゴリズムの詳細な例分析

PHP再帰アルゴリズムの詳細な例分析

ウェブサイトを構築する場合、プログラマーの最初の選択肢は PHP 言語です。 PHP については十分理解できました。次に、PHP の再帰アルゴリズムを紹介します。ネストされた頭字語名である PHP は、英語の Hypertext Preprocessing Language (PHP: Hypertext Preprocessor) の略語です。

#t#PHP は HTML 埋め込み言語です。HTML ドキュメントに埋め込まれ、サーバー側で実行されるスクリプト言語です。言語スタイルは C 言語に似ており、現在多くの Web サイト プログラマーに広く使用されています。 PHP のユニークな構文は、C、Java、Perl、そして PHP 独自の革新的な構文が混在したものです。

CGI や Perl よりも高速に動的な Web ページを実行できます。 PHPなどのプログラミング言語で作成された動的なページと比較すると、PHPはプログラムをHTML文書に埋め込んで実行するため、HTMLタグを完全に生成するCGIよりも実行効率がはるかに高くなります。また、同じくHTML文書に埋め込まれるスクリプト言語であるJavaScriptと比較すると、PHPはサーバー側で実行されるため、サーバーのパフォーマンスを最大限に活用できます。また、PHP実行エンジンは、ユーザーが頻繁にアクセスするPHPプログラムをメモリ上に常駐させます。他のユーザーが再度プログラムにアクセスしたとき、プログラムを再コンパイルする必要はなく、メモリ上のコードを直接実行できます。これもPHPの高効率性の現れの1つです。

PHP は非常に強力な機能を備えています。すべての CGI または JavaScript 機能を実装でき、ほぼすべての一般的なデータベースとオペレーティング システムをサポートします。ここでは PHP の再帰アルゴリズムを詳しく紹介します。

PHP 再帰アルゴリズム コード:

  1. < ?php
  2. // PI の 1 分間の角度値を定義します。define("PII",M_PI/180);
  3. //新しい画像リソースを作成し、背景色を白、前景色を黒に定義します
  4. $ im =イメージを作成します(670,500);
  5. $ white = imagecolorallocate ($im,0xFF,0xFF,0xFF);
  6. $ g =イメージカラー割り当て($im,0x00,0x00,0x00);
  7. //以下のインスタンス化コードから、$x、$y、$L、$aの初期値はそれぞれ300、500、100、270であることがわかります。
  8. 関数drawLeaf($g,$x,$y,$L,$a)
  9. { global$im; $ B = 50 ; $ C = 9 ; $ s1 = 2 ; $ s2 = 3 ; $ s3 = 1.2 ;
  10. $L > $s1の場合{
  11. // 葉の位置を計算する
  12. $ x2 =$x+$L*cos($a*PII);
  13. $ y2 =$y+$L*sin($a*PII);
  14. $ x2R =$x2+$L/$s2*cos(($a+$B)*PII);
  15. $ y2R =$y2+$L/$s2*sin(($a+$B)*PII);
  16. $ x2L =$x2+$L/$s2*cos(($a-$B)*PII);
  17. $ y2L =$y2+$L/$s2*sin(($a-$B)*PII);
  18. //以下の葉の位置を計算する
  19. $ x1 = $x + $L / $s2*cos($a*PII);
  20. $ y1 =$y+$L/$s2*sin($a*PII);
  21. $ x1L =$x1+$L/$s2*cos(($a-$B)*PII);
  22. $ y1L =$y1+$L/$s2*sin(($a-$B)*PII);
  23. $ x1R = $ x1 + $ L / $ s2 * cos ( ($ a + $ B ) * PII );
  24. $ y1R =$y1+$L/$s2*sin(($a+$B)*PII);
  25. //幹と葉の表面を別々に描画する
  26. イメージライン($im,(int)$x,(int)$y,(int)$x2,(int)$y2,$g);
    イメージライン($im、(int)$x2、(int)$y2、(int)$x2R、(int)$y2R、$g);
    イメージライン($im、(int)$x2、(int)$y2、(int)$x2L、(int)$y2L、$g);
    イメージライン($im、(int)$x1、(int)$y1、(int)$x1L、(int)$y1L、$g);
    イメージライン($im、(int)$x1、(int)$y1、(int)$x1R、(int)$y1R、$g);
  27. // 自分自身を再帰的に再度呼び出す
  28. 葉っぱを描きます($g,$x2,$y2,$L/$s3,$a+$C);
  29. 葉っぱを描きます($g,$x2R,$y2R,$L/$s2,$a+$B);
  30. 葉を描きます($g,$x2L,$y2L,$L/$s2,$a-$B);
  31. 葉を描きます($g,$x1L,$y1L,$L/$s2,$a-$B);
  32. 葉を描きます($g,$x1R,$y1R,$L/$s2,$a+$B);
  33. }
  34. }
  35. //インスタンス化
  36. リーフを描画します($g,300,500,100,270);
  37. ヘッダー("コンテンツタイプ:image/png");
  38. イメージpng($im);
  39. ?>  

私の個人的な PHP プログラミング経験では、再帰呼び出しは静的変数とともによく使用されます。静的変数の意味については、PHP マニュアルを参照してください。次のコードが PHP の再帰アルゴリズムと静的変数の理解に役立つことを願っています。

  1. ヘッダー("Content-type:text/plain"); 関数 static_function()
  2. {
  3. 静的$ i = 0 ;
  4. $i++ < 10場合
  5. {
  6. echo$i."\n";
  7. 静的関数();
  8. }
  9. }
  10. 静的関数();

この PHP 再帰アルゴリズム コードは、1 から 10 までの数字を出力します。 static_function 関数が 2 回目に実行されると、変数 i は静的変数であるため保持され解放されず、自己増分された値を取得できます。

<<:  無線ルーターのさまざまな暗号化アルゴリズムの包括的な説明

>>:  PHP 再帰アルゴリズムとアプリケーションの紹介

ブログ    

推薦する

...

1,000元の予算で半日のトレーニングを実施し、その効果は主流の大型モデル、オープンソース、市販の中国製LLaMA-2に匹敵する。

LLaMA-1 と比較して、LLaMA-2 はより高品質のコーパスを導入し、大幅なパフォーマンスの...

人工知能に対する期待と不安

AI は世界を変えようとしていますが、問題は、それがどのように起こるか誰も予測できないことです。過去...

2021 年の優れた 5 つの人工知能フレームワーク

この記事では、上位 5 つのフレームワークとライブラリを実際のアプリケーションとともに紹介したいと思...

労働者は一生懸命働かなければなりません! AI仮想人間が労働力に参入しようとしている

[[413812]]この記事はAI新メディアQuantum Bit(公開アカウントID:QbitAI...

...

ディープラーニングAIを使用してマルウェアやAPTを検出し、防止する方法

[[163896]] [51CTO.com クイック翻訳] Deep Instinct は、最大 9...

アプリケーション管理における AI/ML のユースケース

[[320826]]概要人工知能ベースの運用 (AIOps) は、人工知能と従来の AM/IM 運用...

サイバーセキュリティにおけるAIの新たな機会を見つける方法

[[383159]]新しいテクノロジーの適用には、多くの場合、プラスの影響とマイナスの影響の両方が伴...

自動運転の研究の方向性は間違っているのか?

1 知覚ソリューション: 純粋な視覚とマルチセンサー融合自動車が自動運転を実現するには、まず周囲を...

...

アルゴリズムを知的財産として保護する方法

Ogilvy は、ロボティック プロセス オートメーションと Microsoft のビジュアル AI...

機械学習分野における社内競争について:博士号を取得しないと就職する資格はないのでしょうか?

[[390714]]機械学習は複雑化していますか? 「博士号なしで機械学習の仕事を得るのはますます...

AIは英語のエッセイを添削できますか? IELTS、CET-4、CET-6の採点、コメント、エラー修正が必要です

この記事はAI新メディアQuantum Bit(公開アカウントID:QbitAI)より許可を得て転載...

...