js封装一个双精度算法实现

在 JavaScript 中,由于浮点数在计算机中的存储机制问题,进行双精度浮点数运算时可能会出现精度丢失的情况,比如 0.1 + 0.2 并不等于 0.3。下面是封装的一些常见双精度算法函数,用于解决加、减、乘、除运算中的精度问题:

1. 加法运算

javascript 复制代码
function accAdd(arg1, arg2) {
    let r1, r2, m;
    try { r1 = arg1.toString().split(".")[1].length } catch (e) { r1 = 0 }
    try { r2 = arg2.toString().split(".")[1].length } catch (e) { r2 = 0 }
    m = Math.pow(10, Math.max(r1, r2));
    return (arg1 * m + arg2 * m) / m;
}

2. 减法运算

javascript 复制代码
function accSub(arg1, arg2) {
    let r1, r2, m, n;
    try { r1 = arg1.toString().split(".")[1].length } catch (e) { r1 = 0 }
    try { r2 = arg2.toString().split(".")[1].length } catch (e) { r2 = 0 }
    m = Math.pow(10, Math.max(r1, r2));
    n = (r1 >= r2)? r1 : r2;
    return ((arg1 * m - arg2 * m) / m).toFixed(n);
}

3. 乘法运算

javascript 复制代码
function accMul(arg1, arg2) {
    let m = 0, s1 = arg1.toString(), s2 = arg2.toString();
    try { m += s1.split(".")[1].length } catch (e) { }
    try { m += s2.split(".")[1].length } catch (e) { }
    return Number(s1.replace(".", "")) * Number(s2.replace(".", "")) / Math.pow(10, m);
}

4. 除法运算

javascript 复制代码
function accDiv(arg1, arg2) {
    let t1 = 0, t2 = 0, r1, r2;
    try { t1 = arg1.toString().split(".")[1].length } catch (e) { }
    try { t2 = arg2.toString().split(".")[1].length } catch (e) { }
    r1 = Number(arg1.toString().replace(".", ""));
    r2 = Number(arg2.toString().replace(".", ""));
    return (r1 / r2) * Math.pow(10, t2 - t1);
}

你可以按照以下方式使用这些函数:

javascript 复制代码
// 示例使用
console.log(accAdd(0.1, 0.2)); 
console.log(accSub(0.3, 0.1)); 
console.log(accMul(0.2, 0.3)); 
console.log(accDiv(0.6, 0.2)); 

上述代码中,accAdd 实现了双精度浮点数的加法,通过获取两个数小数部分的位数,将它们转换为整数进行加法运算,再将结果转换回浮点数;accSub 实现减法,逻辑和加法类似,最后根据小数位数较多的那个数来保留结果的小数位数;accMul 用于乘法运算,先统计两个数小数部分的总位数,将两个数转换为整数相乘后再除以对应的倍数得到结果;accDiv 实现除法运算,先获取两个数小数部分的位数,将它们转换为整数相除,再根据位数差异调整结果。

相关推荐
froginwe1116 分钟前
DOM 加载函数
开发语言
Hello eveybody32 分钟前
介绍一下背包DP(Python)
开发语言·python·动态规划·dp·背包dp
AI进化营-智能译站1 小时前
ROS2 C++开发系列12-用多态与虚函数构建可扩展的ROS2机器人行为模块
开发语言·c++·ai·机器人
iCxhust1 小时前
微机原理实践教程(C语言篇)---A002流水灯
c语言·开发语言·单片机·嵌入式硬件·51单片机·课程设计·微机原理
是上好佳佳佳呀1 小时前
【前端(十一)】JavaScript 语法基础笔记(多语言对比)
前端·javascript·笔记
莎士比亚的文学花园1 小时前
Linux驱动开发(3)——设备树
开发语言·javascript·ecmascript
图码1 小时前
如何用多种方法判断字符串是否为回文?
开发语言·数据结构·c++·算法·阿里云·线性回归·数字雕刻
U盘失踪了1 小时前
python curl转python脚本
开发语言·chrome·python
charlie1145141911 小时前
Linux 字符设备驱动:cdev、设备号与设备模型
linux·开发语言·驱动开发·c
handler011 小时前
Linux 内核剖析:进程优先级、上下文切换与 O(1) 调度算法
linux·运维·c语言·开发语言·c++·笔记·算法