当前位置:首页 > JavaScript

js 实现sqrt

2026-02-01 02:54:45JavaScript

实现平方根的 JavaScript 方法

使用 Math.sqrt()

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

js 实现sqrt

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

二分查找法

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

js 实现sqrt

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
  • 设定合理的精度阈值避免无限循环
  • 对极大/极小数值需考虑浮点数精度问题

标签: jssqrt
分享给朋友:

相关文章

js实现全选

js实现全选

实现全选功能的方法 在JavaScript中实现全选功能通常涉及监听全选复选框的点击事件,并根据其状态控制其他复选框的选中状态。以下是几种常见的实现方式: 基础DOM操作实现 通过获取所有目标复选框…

js实现图片放大缩小

js实现图片放大缩小

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

js分组实现

js分组实现

分组实现方法 在JavaScript中,可以通过多种方式实现数组或对象的分组操作。以下是几种常见的方法: 使用Array.prototype.reduce() 通过reduce方法可以轻松实现数组分…

js类实现

js类实现

使用类实现 JavaScript 功能 在 JavaScript 中,类(Class)是一种语法糖,基于原型继承机制。通过 class 关键字可以更直观地定义对象模板。 基本类定义 class…

js实现搜索

js实现搜索

实现搜索功能的方法 在JavaScript中实现搜索功能可以通过多种方式完成,以下是几种常见的实现方法。 使用数组的filter方法 通过数组的filter方法可以筛选出符合条件的数据项。假设有一个…

js进度条实现

js进度条实现

使用HTML和CSS创建基础结构 在HTML中创建一个容器元素用于显示进度条,通常使用<div>元素。CSS用于设置进度条的样式,包括宽度、高度、颜色和圆角等属性。 <div cl…