bcdiv

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

bcdivDivide dois números de precisão arbitrária

Descrição

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

Divide num1 por num2.

Parâmetros

num1

O dividendo, como uma string.

num2

O divisor, como uma string.

scale
Este parâmetro é usado para definir o número de dígitos após o separador de decimais do resultado. Se for null, será usada a escala padrão definida com bcscale(), ou será usado o valor da diretiva INI bcmath.scale.

Valor Retornado

Retorna o resultado da divisão como uma string.

Erros/Exceções

Esta função lança uma exceção ValueError nos seguintes casos:

  • num1 ou num2 não for uma string numérica BCMath bem formada.
  • scale estiver fora do intervalo válido.

Esta função lança uma exceção DivisionByZeroError se num2 for igual a 0.

Registro de Alterações

Versão Descrição
8.0.0 scale agora pode ser nulo.
8.0.0 Dividir por 0 agora lança uma exceção DivisionByZeroError ao invés de retornar null.

Exemplos

Exemplo #1 Exemplo de bcdiv()

<?php

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

?>

Veja Também

  • bcdivmod() - Obtém o quociente e o módulo de um número de precisão arbitrário
  • bcmod() - Obtém o resto de uma divisão com precisão arbitrária
  • bcmul() - Multiplica dois números de precisão arbitrária
  • BcMath\Number::div() - Divide por um número de precisão arbitrária

adicione uma nota

Notas Enviadas por Usuários (em inglês) 1 note

up
0
MM
17 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