【LeetCode算法】第69题:x的平方根

目录

一、题目描述

二、初次解答

三、官方解法

四、总结


一、题目描述

二、初次解答

1. 思路:第一次 想到的是让i从1开始遍历,看i*i==x是否成立,但是这样就会导致i*i超出了int的范围,无法正常求解。第二次 ,想着比较x/i与i的绝对值是否小于等于1,是的话x/i与i的最小值就是x的平方因数。虽然第二次这种方法可行,但是速度就很慢(以下代码就是第二次想到的方法)。第三次 ,想到提升查找效率能否使用二分查找,但是二分查找中间值时比较中间值的平方与x也会超出int界限,因此无从下手。结果 ,官方给出的二分查找中计算i*i时强转为long long,这样其他计算的数据都会自动类型提升至long long,就避免了超出int的局限性。但是如果未来遇到更大的数据类型时岂不是仍然不行。

2. 代码:

cpp 复制代码
int mySqrt(int x) {
    int i = 1;
    while (1){
        int ret = x / i;
        if (ret == i || ret == i - 1 || ret == i + 1) {
            return ret > i ? i : ret;
        } else {
            ++i;
        }
    }
}

**3. 优点:**容易想到,代码简单。

**4. 缺点:**因为每次都从1开始,执行速度非常慢。

三、官方解法

**1. 思路:牛顿迭代法,可以快速求解函数零点问题f(x)=0。**任取一个xi,通过牛顿迭代法获得xi+1,更接近函数零点。牛顿迭代法的实现与原理如下图所示:

2. 代码:

cpp 复制代码
int mySqrt(int x) {
    if (x == 0)
        return 0;
    double x0 = x;
    while (1){
        double xi = (x0 + x / x0) / 2;
        if (fabs(xi - x0) < 1e-7)
            break;
        x0 = xi;
    }
    return x0;
}

**3. 优点:**运行速度快。

**4. 缺点:**第一次难以想到。

四、总结

遇到代数方程难以求解时,将其转换为函数零点问题,用牛顿迭代法求解。

相关推荐
Kuo-Teng16 分钟前
LeetCode 19: Remove Nth Node From End of List
java·数据结构·算法·leetcode·链表·职场和发展·list
Kuo-Teng20 分钟前
LeetCode 21: Merge Two Sorted Lists
java·算法·leetcode·链表·职场和发展
2301_8003997231 分钟前
stm32 printf重定向到USART
java·stm32·算法
小龙报37 分钟前
《嵌入式成长系列之51单片机 --- Keil5创建工程》
c语言·开发语言·c++·单片机·嵌入式硬件·51单片机·学习方法
无限进步_1 小时前
【C语言】贪吃蛇游戏设计思路深度解析:从零开始理解每个模块
c语言·开发语言·c++·git·游戏·github·visual studio
顾安r2 小时前
11.15 脚本算法 加密网页
服务器·算法·flask·html·同态加密
前端小L2 小时前
图论专题(四):DFS的“回溯”之舞——探寻「所有可能路径」
算法·深度优先·图论
司铭鸿2 小时前
数学图论的艺术:解码最小公倍数图中的连通奥秘
运维·开发语言·算法·游戏·图论
元亓亓亓2 小时前
LeetCode热题100--39. 组合总和
算法·leetcode·职场和发展
2401_841495643 小时前
【LeetCode刷题】找到字符串中所有字母异位词
数据结构·python·算法·leetcode·数组·滑动窗口·找到字符串中所有字母异位词