PHP 8.4.0 RC4 available for testing

bcdiv

(PHP 4, PHP 5, PHP 7, PHP 8)

bcdiv2つの任意精度数値で除算を行う

説明

bcdiv(string $num1, string $num2, ?int $scale = null): string

num1num2 で除算します。

パラメータ

num1

被除数を表す文字列。

num2

割る数を表す文字列。

scale

このオプションパラメータを使用して、結果の小数点以下の桁数を指定します。省略した場合は、bcscale() 関数でグローバルに設定した桁数をデフォルトとして使用します。それも設定されていない場合は 0 を使用します。

戻り値

除算結果を文字列で返します。 num2 が 0 の場合は null を返します。

変更履歴

バージョン 説明
8.0.0 scale は、nullable になりました。

例1 bcdiv() の例

<?php

echo bcdiv('105', '6.55957', 3); // 16.007

?>

参考

  • bcmul() - 2つの任意精度数値の乗算を行う

add a note

User Contributed Notes 1 note

up
0
MM
16 years ago
Perhaps some one can find useful this function to compute the modular inverse of a integer (extended euclidean algorithm):

function invmod($a,$b) {
$n=$b;
$x=0; $lx=1; $y=1; $ly=0;
while ($b) {
$t=$b;
$q=bcdiv($a,$b,0);
$b=bcmod($a,$b);
$a=$t;
$t=$x; $x=bcsub($lx,bcmod(bcmul($q,$x),$n)); $lx=$t;
$t=$y; $y=bcsub($ly,bcmod(bcmul($q,$y),$n)); $ly=$t;
}
if (bccomp($lx,0) == -1)
$lx=bcadd($lx,$n);
return $lx;
}

// verify

$n="2447995268898324993537772139997802321";
$t="64941057316178801556773346239351236811";
$m="123456789";
$i=invmod($t,$n);
// (t*m)*inv(t) is m
echo bcmod(bcmul(bcmod(bcmul($t,$m),$n),$i),$n) == $m;
To Top