PHP プログラムを通じて指定された数値 n の階乗を計算する方法
前の記事「PHP ループ学習 9: 指定された 2 つの数値間の最大公約数を取得する」では、while ループ ステートメントを使用して指定された 2 つの整数間の最大公約数を見つける方法を紹介しました。 、今回は階乗について説明し、指定された整数 N の階乗を計算する方法を紹介します。興味のある友達はそれについて学ぶことができます~
まず第一に、理解しましょう階乗とは何ですか?
正の整数の階乗は、その数値以下のすべての正の整数の積です。したがって、指定された整数 N の階乗は次のようになります。
1 × 2 × 3×...× (n-1) × n
階乗の求め方は次のとおりです。 simple は、プログラミングを始めたばかりの学生が必ず遭遇するプログラミングの問題であり、実装する方法はたくさんあります。この記事では、for ループ、while ループ、do-while ループ、再帰の観点から階乗を実装するさまざまな方法を紹介します。
方法 1: for ループを使用して N
の階乗を実装する実装アイデア:
階乗を見つけるためof n は、1 掛ける 2 掛ける 3 の積を n まで求めます。したがって、for ループの初期条件は
i = 1
に設定でき、制限条件はi または <code>i <n><br></n>
- ループ本体は乗算演算です。各ループの i 値を乗算して積を取得します
- 最後にプロダクトを出力します。
<?php header("Content-type:text/html;charset=utf-8"); //第一种方法--for循环 function Factorial($n) { $sum = 1; for ($i = 1; $i <= $n; $i++) { $sum *= $i; } echo "$n 的阶乘为: " . $sum."<br><br>"; } Factorial(5); Factorial(10); Factorial(100); ?>
$sum *= $iこのステートメントは # と同等です。 ##$sum=$sum*$i
, *=
代入演算子は、演算子の左側の変数と右側の式の値を乗算し、それを次の式に代入できます。左側の変数。注: 値に 0 を乗算すると 0 になるため、変数 $sum の初期値は 1 でなければなりません。 出力結果を見てみましょう:
#for ループが N の階乗を実装する方法を理解しました。 while ループの実装方法do-while ループも、私が知っていることのほとんどすべてです (実装の考え方は同じです)。
<?php
header("Content-type:text/html;charset=utf-8");
//第二种方法--while循环
function Factorial($n) {
$i = 1;
$sum=1;
while($i<=$n){
$sum*=$i;
$i++;
}
echo "$n 的阶乘为: " . $sum."<br><br>";
}
Factorial(1);
Factorial(2);
Factorial(3);
Factorial(11);
?>
<?php
header("Content-type:text/html;charset=utf-8");
//第三种方法--do while循环
function Factorial($n) {
$i = 1;
$sum=1;
do {
$sum *= $i;
$i++;
} while ($i <= $n);
echo "$n 的阶乘为: " . $sum."<br><br>";
}
Factorial(2);
Factorial(3);
Factorial(4);
Factorial(10);
?>
メソッド 1、メソッドを比較します。 2 と方法 3. 非常に似ていることがわかりましたか!
さて、ここでもう一つ重要な点が来ました。再帰が N の階乗をどのように実装するかを見てみましょう。
方法 4: 再帰を使用して Nの階乗を実装する では、再帰とは何でしょうか。簡単に言えば、再帰とは、プログラムがそれ自体を呼び出し、参照先のオブジェクトが判明するまで関数がそれ自体を参照し続けることを意味します。再帰を構成するには、次の 2 つの条件が満たされる必要があります。
- サブ問題は、元の問題と同じであり、より単純である必要があります。
- 自分自身を無制限に呼び出すことはできません。出口が必要であり、非再帰的な状況処理に簡素化できます。
- 再帰的思考によれば、階乗は次の式で表すことができます:
f(1) = 1 f(n) = n * f(n-1) {n>1}
したがって、PHP を使用して N 階乗を再帰的に求めるコードは次のとおりです。 ##
<?php header("Content-type:text/html;charset=utf-8"); //第四种方法--递归 function Factorial($n) { $sum=1; if($n <= 1){ return 1; }else{ $sum = $n * factorial($n-1); return $sum; } } echo "2 的阶乘为: " .Factorial(2)."<br><br>"; echo "3 的阶乘为: " .Factorial(3)."<br><br>"; echo "4 的阶乘为: " .Factorial(4)."<br><br>"; echo "10 的阶乘为: " .Factorial(10); ?>
わかりました。他に知りたいことがあれば、ここをクリックしてください。 → →php ビデオチュートリアル
以上がPHP プログラムを通じて指定された数値 n の階乗を計算する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

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

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

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









PHP 8.4 では、いくつかの新機能、セキュリティの改善、パフォーマンスの改善が行われ、かなりの量の機能の非推奨と削除が行われています。 このガイドでは、Ubuntu、Debian、またはその派生版に PHP 8.4 をインストールする方法、または PHP 8.4 にアップグレードする方法について説明します。

あなたが経験豊富な PHP 開発者であれば、すでにそこにいて、すでにそれを行っていると感じているかもしれません。あなたは、運用を達成するために、かなりの数のアプリケーションを開発し、数百万行のコードをデバッグし、大量のスクリプトを微調整してきました。

Visual Studio Code (VS Code とも呼ばれる) は、すべての主要なオペレーティング システムで利用できる無料のソース コード エディター (統合開発環境 (IDE)) です。 多くのプログラミング言語の拡張機能の大規模なコレクションを備えた VS Code は、

JWTは、JSONに基づくオープン標準であり、主にアイデンティティ認証と情報交換のために、当事者間で情報を安全に送信するために使用されます。 1。JWTは、ヘッダー、ペイロード、署名の3つの部分で構成されています。 2。JWTの実用的な原則には、JWTの生成、JWTの検証、ペイロードの解析という3つのステップが含まれます。 3. PHPでの認証にJWTを使用する場合、JWTを生成および検証でき、ユーザーの役割と許可情報を高度な使用に含めることができます。 4.一般的なエラーには、署名検証障害、トークンの有効期限、およびペイロードが大きくなります。デバッグスキルには、デバッグツールの使用とロギングが含まれます。 5.パフォーマンスの最適化とベストプラクティスには、適切な署名アルゴリズムの使用、有効期間を合理的に設定することが含まれます。

このチュートリアルでは、PHPを使用してXMLドキュメントを効率的に処理する方法を示しています。 XML(拡張可能なマークアップ言語)は、人間の読みやすさとマシン解析の両方に合わせて設計された多用途のテキストベースのマークアップ言語です。一般的にデータストレージに使用されます

文字列は、文字、数字、シンボルを含む一連の文字です。このチュートリアルでは、さまざまな方法を使用してPHPの特定の文字列内の母音の数を計算する方法を学びます。英語の母音は、a、e、i、o、u、そしてそれらは大文字または小文字である可能性があります。 母音とは何ですか? 母音は、特定の発音を表すアルファベットのある文字です。大文字と小文字など、英語には5つの母音があります。 a、e、i、o、u 例1 入力:string = "tutorialspoint" 出力:6 説明する 文字列「TutorialSpoint」の母音は、u、o、i、a、o、iです。合計で6元があります

静的結合(静的::) PHPで後期静的結合(LSB)を実装し、クラスを定義するのではなく、静的コンテキストで呼び出しクラスを参照できるようにします。 1)解析プロセスは実行時に実行されます。2)継承関係のコールクラスを検索します。3)パフォーマンスオーバーヘッドをもたらす可能性があります。

PHPの魔法の方法は何ですか? PHPの魔法の方法には次のものが含まれます。1。\ _ \ _コンストラクト、オブジェクトの初期化に使用されます。 2。\ _ \ _リソースのクリーンアップに使用される破壊。 3。\ _ \ _呼び出し、存在しないメソッド呼び出しを処理します。 4。\ _ \ _ get、dynamic属性アクセスを実装します。 5。\ _ \ _セット、動的属性設定を実装します。これらの方法は、特定の状況で自動的に呼び出され、コードの柔軟性と効率を向上させます。
