array ( 0 => 'index.php', 1 => 'PHP Manual', ), 'head' => array ( 0 => 'UTF-8', 1 => 'uk', ), 'this' => array ( 0 => 'function.bcdivmod.php', 1 => 'bcdivmod', 2 => 'Get the quotient and modulus of an arbitrary precision number', ), 'up' => array ( 0 => 'ref.bc.php', 1 => 'Функції BC Math', ), 'prev' => array ( 0 => 'function.bcdiv.php', 1 => 'bcdiv', ), 'next' => array ( 0 => 'function.bcfloor.php', 1 => 'bcfloor', ), 'alternatives' => array ( ), 'source' => array ( 'lang' => 'en', 'path' => 'reference/bc/functions/bcdivmod.xml', ), 'history' => array ( ), ); $setup["toc"] = $TOC; $setup["toc_deprecated"] = $TOC_DEPRECATED; $setup["parents"] = $PARENTS; manual_setup($setup); contributors($setup); ?>

bcdivmod

(PHP 8 >= 8.4.0)

bcdivmodGet the quotient and modulus of an arbitrary precision number

Опис

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

Get the quotient and remainder of dividing num1 by num2.

Параметри

num1

The dividend, as a string.

num2

The divisor, as a string.

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 the bcmath.scale INI directive.

Значення, що повертаються

Returns an indexed array where the first element is the quotient as a string and the second element is the remainder as a string.

Помилки/виключення

This function throws a ValueError in the following cases:

This function throws a DivisionByZeroError exception if num2 is 0.

Приклади

Приклад #1 bcdivmod() example

<?php
bcscale
(0);

[
$quot, $rem] = bcdivmod('5', '3');
echo
$quot; // 1
echo $rem; // 2

[$quot, $rem] = bcdivmod('5', '-3');
echo
$quot; // -1
echo $rem; // 2

[$quot, $rem] = bcdivmod('-5', '3');
echo
$quot; // -1
echo $rem; // -2

[$quot, $rem] = bcdivmod('-5', '-3');
echo
$quot; // 1
echo $rem; // -2
?>

Приклад #2 bcdivmod() with decimals

<?php
[$quot, $rem] = bcdivmod('5.7', '1.3', 1);
echo
$quot; // 4
echo $rem; // 0.5
?>

Прогляньте також