bcdiv
(PHP 4, PHP 5, PHP 7, PHP 8)
bcdiv — 2つの任意精度数値で除算を行う
パラメータ
num1
-
被除数を表す文字列。
num2
-
割る数を表す文字列。
scale
-
This parameter is used to set the number of digits after the decimal place in the result.
If
null
, it will default to the default scale set with bcscale(), or fallback to the value of thebcmath.scale
INI directive.
戻り値
除算結果を文字列で返します。
num2
が 0
の場合は null
を返します。
エラー / 例外
This function throws a ValueError in the following cases:
-
num1
ornum2
is not a well-formed BCMath numeric string. -
scale
is outside the valid range.
This function throws a DivisionByZeroError
exception if num2
is 0
.
変更履歴
バージョン | 説明 |
---|---|
8.0.0 |
scale は、nullable になりました。
|
例
例1 bcdiv() の例
<?php
echo bcdiv('105', '6.55957', 3); // 16.007
?>
+add a note
User Contributed Notes 1 note
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;
↑ and ↓ to navigate •
Enter to select •
Esc to close
Press Enter without
selection to search using Google