当前位置:首页 > JavaScript

js 实现sqrt

2026-02-01 02:54:45JavaScript

实现平方根的 JavaScript 方法

使用 Math.sqrt()

JavaScript 内置了 Math.sqrt() 方法,可直接计算平方根:

const result = Math.sqrt(9); // 返回 3

二分查找法

对于不依赖内置方法的实现,可通过二分查找逼近平方根值:

function sqrt(x) {
    if (x < 0) return NaN;
    if (x === 0 || x === 1) return x;

    let low = 0;
    let high = x;
    let precision = 0.00001;
    let mid;

    while (high - low > precision) {
        mid = (low + high) / 2;
        if (mid * mid > x) {
            high = mid;
        } else {
            low = mid;
        }
    }
    return (low + high) / 2;
}

牛顿迭代法

更高效的数值计算方法,通过迭代公式快速逼近结果:

function sqrtNewton(x) {
    if (x < 0) return NaN;
    let guess = x / 2;
    const precision = 0.00001;

    while (Math.abs(guess * guess - x) > precision) {
        guess = (guess + x / guess) / 2;
    }
    return guess;
}

性能比较

  • Math.sqrt() 是原生实现,速度最快
  • 牛顿迭代法通常比二分查找收敛更快
  • 自定义实现适合理解算法原理或特殊需求场景

注意事项

  • 处理负数输入返回 NaN
  • 设定合理的精度阈值避免无限循环
  • 对极大/极小数值需考虑浮点数精度问题

js 实现sqrt

标签: jssqrt
分享给朋友:

相关文章

js实现打印

js实现打印

使用window.print()方法实现打印 在JavaScript中,可以通过调用window.print()方法直接触发浏览器的打印功能。这会打开系统的打印对话框,用户可以选择打印机和设置打印选项…

js实现文件下载

js实现文件下载

使用 a 标签下载文件 通过动态创建 a 标签并设置 download 属性实现文件下载。适用于已知文件 URL 或 Blob 数据的情况。 function downloadFile(url,…

js实现图片上传

js实现图片上传

图片上传的基本实现 使用HTML的<input type="file">元素配合JavaScript的File API可以实现图片上传功能。HTML部分需要创建一个文件选择输入框和一个用于…

js 实现继承

js 实现继承

原型链继承 通过让子类的原型对象指向父类的实例来实现继承。子类实例可以访问父类原型上的属性和方法。 function Parent() { this.name = 'parent'; } Par…

js实现图片放大缩小

js实现图片放大缩小

实现图片放大缩小的基础方法 使用CSS的transform: scale()属性可以快速实现图片的放大缩小效果。通过JavaScript动态修改该属性值: const img = document…

js实现类

js实现类

JavaScript 实现类的几种方式 JavaScript 是一种基于原型的语言,但在 ES6 之后引入了 class 语法糖,使得实现类更加直观。以下是几种常见的实现方式: 使用构造函数 传统的…