bcadd

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

bcadd添加两个任意精度的数字

描述

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

num1num2 相加。

参数

num1

左操作数,作为字符串。

num2

右操作数,作为字符串。

scale

此可选参数用于设置结果中小数点后的位数。如果省略,它将默认为使用 bcscale() 函数全局设置的比例,或者如果未设置则回退到 0

返回值

两个操作数的和,作为字符串。

变更日志

版本 描述
8.0.0 scale 现在可以为空。

示例

示例 #1 bcadd() 示例

<?php

$a
= '1.234';
$b = '5';

echo
bcadd($a, $b); // 6
echo bcadd($a, $b, 4); // 6.2340

?>

参见

  • bcsub() - 从另一个任意精度的数字中减去一个数字

添加备注

用户贡献的备注 2 条备注

23
Nitrogen
15 年前
我制作了这个来将无限大小的数字加在一起。

这对那些没有 BCMath 扩展的人来说可能很有用。

它允许小数,以及可选的 $Scale 参数。如果未指定 $Scale,则它将自动调整以显示正确的小数位数。

<?php

function Add($Num1,$Num2,$Scale=null) {
// 检查它们是否为有效的正数,提取整数和小数部分
if(!preg_match("/^\+?(\d+)(\.\d+)?$/",$Num1,$Tmp1)||
!
preg_match("/^\+?(\d+)(\.\d+)?$/",$Num2,$Tmp2)) return('0');

// 存储结果
$Output=array();

// 删除小数部分末尾的零并移除小数点
$Dec1=isset($Tmp1[2])?rtrim(substr($Tmp1[2],1),'0'):'';
$Dec2=isset($Tmp2[2])?rtrim(substr($Tmp2[2],1),'0'):'';

// 计算小数部分的最大长度
$DLen=max(strlen($Dec1),strlen($Dec2));

// 如果 $Scale 为空,则自动将其设置为小数位数,以保证精度
if($Scale==null) $Scale=$DLen;

// 删除整数部分前导零,并反转整数部分,然后在末尾添加填充的小数部分
$Num1=strrev(ltrim($Tmp1[1],'0').str_pad($Dec1,$DLen,'0'));
$Num2=strrev(ltrim($Tmp2[1],'0').str_pad($Dec2,$DLen,'0'));

// 计算需要处理的最大长度
$MLen=max(strlen($Num1),strlen($Num2));

// 填充两个数字,使其长度相同(都等于 $MLen)
$Num1=str_pad($Num1,$MLen,'0');
$Num2=str_pad($Num2,$MLen,'0');

// 处理每个数字,保留个位数,进位十位数(余数)
for($i=0;$i<$MLen;$i++) {
$Sum=((int)$Num1{$i}+(int)$Num2{$i});
if(isset(
$Output[$i])) $Sum+=$Output[$i];
$Output[$i]=$Sum%10;
if(
$Sum>9) $Output[$i+1]=1;
}

// 将数组转换为字符串并反转它
$Output=strrev(implode($Output));

// 从结果中提取小数位,必要时进行填充(如果 $Scale 大于实际小数位数)
// 接下来,由于实际零值会导致子字符串值的故障,如果是这样,就简单地返回 '0'
// 接下来,附加小数部分的值,如果 $Scale 已定义,并返回结果
$Decimal=str_pad(substr($Output,-$DLen,$Scale),$Scale,'0');
$Output=(($MLen-$DLen<1)?'0':substr($Output,0,-$DLen));
$Output.=(($Scale>0)?".{$Decimal}":'');
return(
$Output);
}

$A="5650175242.508133742";
$B="308437806.831153821478770";

printf(" Add(%s,%s);\r\n// %s\r\n\r\n",$A,$B, Add($A,$B));
printf("BCAdd(%s,%s);\r\n// %s\r\n\r\n",$A,$B,BCAdd($A,$B));

/*
这将生成以下内容..
Add(5650175242.508133742,308437806.831153821478770);
// 5958613049.33928756347877

BCAdd(5650175242.508133742,308437806.831153821478770);
// 5958613049
*/

?>

制作这个过程很有趣,我想与大家分享。
享受吧,
氮气。
9
Bo Anders Svensson
19 年前
注意

$exp1 = "1E5";
$exp2 = "2E4";

$ans1 = bcadd((float)$exp1, (float)$exp2, 3);
$ans2 = bcadd((int)$exp1, (int)$exp2, 3);
$ans3 = bcadd($exp1, $exp2, 3);

echo "1: $exp1 + $exp2 = $ans1\r\n";
echo "2: $exp1 + $exp2 = $ans2\r\n";
echo "3: $exp1 + $exp2 = $ans3\r\n";

1: 1E5 + 2E4 = 120000.000
2: 1E5 + 2E4 = 3.000
3: 1E5 + 2E4 = 0.000
To Top