PHP で書かれた効率的なフィボナッチ数列計算機

PHPz
リリース: 2024-03-21 10:10:02
オリジナル
1151 人が閲覧しました

PHP で書かれた効率的なフィボナッチ数列計算機

効率的なフィボナッチ数列計算機: PHP の実装

フィボナッチ数列 (フィボナッチ数列) は非常に古典的な数学です。ルールは、各数値が等しいということです。前の 2 つの数値の合計、つまり F(n) = F(n-1) F(n-2) になります。ここで、F(0) = 0 および F(1) = 1。フィボナッチ数列を計算する場合、再帰的に実装できますが、値が増加するにつれてパフォーマンスの問題が発生します。したがって、この記事では、パフォーマンスの問題を回避するために、PHP を使用して効率的なフィボナッチ数列計算機を作成する方法を紹介します。

アルゴリズム設計

効率的なフィボナッチ数列計算器を設計する場合、動的プログラミングの考え方を使用して、計算の繰り返しを回避し、すでに計算された値を保存することで計算効率を向上させることができます。具体的な実装は次のとおりです。

function fib($n) {
    $fibArr = 配列();
    $fibArr[0] = 0;
    $fibArr[1] = 1;

    for ($i = 2; $i <= $n; $i ) {
        $fibArr[$i] = $fibArr[$i - 1] $fibArr[$i - 2];
    }

    $fibArr[$n] を返します;
}

// テストコード
$n = 10; // n番目のフィボナッチ数を計算したい
$result = fib($n);
echo "{$n} 番目のフィボナッチ数は: {$result}";
ログイン後にコピー

上記のコードでは、まず配列 $fibArr を定義して、フィボナッチ数列の計算を保存します。次に、ループを通じて n 番目のフィボナッチ数を計算し、最後に結果を返します。

プログラムの最適化

動的プログラミングを使用してフィボナッチ数列計算を最適化することに加えて、プログラムのパフォーマンスをさらに最適化することもできます。最適化方法の 1 つは、行列の形式でフィボナッチ数列を計算することにより、計算時間の複雑さを O(logn) レベルに減らすことです。

関数べき乗($matrix, $n) {
    if ($n == 1) {
        $matrix を返します。
    }

    $result = power($matrix, intval($n / 2));
    $result = multiplyMatrix($result, $result);

    if ($n % 2 == 1) {
        $result = multiplyMatrix($result, $matrix);
    }

    $result を返します。
}

関数 multiplyMatrix($matrix1, $matrix2) {
    $result = 配列();

    $result[0] = $matrix1[0] * $matrix2[0] $matrix1[1] * $matrix2[2];
    $result[1] = $matrix1[0] * $matrix2[1] $matrix1[1] * $matrix2[3];
    $result[2] = $matrix1[2] * $matrix2[0] $matrix1[3] * $matrix2[2];
    $result[3] = $matrix1[2] * $matrix2[1] $matrix1[3] * $matrix2[3];

    $result を返します。
}

関数 fib_optimized($n) {
    $matrix = 配列(1, 1, 1, 0);
    $result = power($matrix, $n - 1);

    $result[0] を返します;
}

// テストコード
$n = 10; // n番目のフィボナッチ数を計算したい
$result = fib_optimized($n);
echo "{$n} 番目のフィボナッチ数は: {$result}";
ログイン後にコピー

上記のコードでは、計算する 2 つの関数 power multiplyMatrix を定義します。行列乗算と行列累乗をそれぞれ実行し、フィボナッチ数列の計算プロセスを最適化します。

上記のコード例を通じて、パフォーマンスの問題を回避し、計算効率を向上させる効率的なフィボナッチ数列計算機を実装しました。実際の開発では、プログラムのパフォーマンスを向上させるための特定のニーズに応じて、適切なアルゴリズムを選択してフィボナッチ数列を計算できます。

以上がPHP で書かれた効率的なフィボナッチ数列計算機の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート