【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. 代码:

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. 代码:

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. 缺点:第一次难以想到。

四、总结

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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/636316.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【css】引入背景图时候,路径写入@会报错

看报错信息 我的写法 解决办法 在前面加个~

表现层框架设计之表现层设计模式_3.MVVM模式

1.MVVM模式 MVVM模式正是为解决MVP中UI种类变多&#xff0c;接口也会不断增加的问题而提出的。 MVVM模式全称是模型-视图-视图模型&#xff08;Model-View-ViewModel&#xff09;&#xff0c;它和MVC、MVP类似&#xff0c;主要目的都是为了实现视图和模型的分离&#xff0c;不…

无线通信的穿墙能力主要取决于哪些指标

无线通信的穿墙能力是指无线信号在穿越建筑物墙壁时&#xff0c;其信号衰减程度以及能否维持足够强度以进行稳定通信的能力。穿墙能力的好坏直接影响到无线通信在室内环境中的覆盖范围和使用体验。 一、无线信号的频率 无线信号的频率是影响穿墙能力的重要因素之一。一般来说…

mybatisPlus-DB静态工具

方法跟mybatisplus的service接口非常像&#xff0c;静态工具可以避免依赖循环注入。

Github 2024-05-24 开源项目日报 Top10

根据Github Trendings的统计,今日(2024-05-24统计)共有10个项目上榜。根据开发语言中项目的数量,汇总情况如下: 开发语言项目数量Python项目3非开发语言项目2TypeScript项目2JavaScript项目1Kotlin项目1C#项目1C++项目1Shell项目1Microsoft PowerToys: 最大化Windows系统生产…

解密短链接数据分析功能,看这篇就够了!

如今&#xff0c;短链接工具那可是越来越成熟了&#xff0c;生成短链接这事儿基本都深入人心了。不管是企业还是个人&#xff0c;在把长链接转成短链接的这个过程里&#xff0c;都得用到数据统计来进行分析。 先说说对企业的好处&#xff0c;短链接数据统计能助力企业摸透用户…

为什么我们应该放弃定义敏感数据?

个人数据与人以及其他个人数据深深地交织在一起&#xff0c;它就像一幅巨大的挂毯&#xff0c;而这些线是无法轻易拆开的。尝试定义敏感数据就像徒劳地试图从挂毯中找出不同的线头一样&#xff0c;线头与其他线头交织在一起&#xff0c;一旦开始拆线&#xff0c;整个挂毯就会散…

【C#】.net core 6.0 在program时间格式统一json格式化,并列举program默认写法和简化写法

欢迎来到《小5讲堂》 这是《C#》系列文章&#xff0c;每篇文章将以博主理解的角度展开讲解。 温馨提示&#xff1a;博主能力有限&#xff0c;理解水平有限&#xff0c;若有不对之处望指正&#xff01; 目录 背景Main入口简化写法统一时间格式相关文章 背景 在.NET Core 6.0中&…

基于xilinx fpga RFSOC系列的Ultrascale+ RF Data Converter ip详解说明

目录 1 概述2 IP功能2.1 ADC性能2.2 DAC性能3 IP端口4 代码框架4.1 ADC功能框图4.2 DAC功能框图5 收发数据时序5.1 ADC数据格式5.2 DAC数据格式6 时钟配置6.1 ADC/DAC参考时钟7 数据格式配置模式7.1 ADC的配置模式7.1.1 Real -> real;7.1.2 Real ->IQ;7.1.3 IQ -> IQ;…

Potree点云手册

兄弟们整理和收集资料不容易&#xff0c;请关注手册&#xff01;&#xff01; Potree 以其高显示速度而脱颖而出&#xff0c;使其成为处理大量点云数据集的绝佳选择。 我们的重点将是 Potree 提供的多样化导航和显示选项。 如果你遇到任何问题&#xff0c;请随时尝试其他浏览器…

25.zabbix升级版本4.0-5.0

zabbix5.0升级要求 环境支持 软件要求&#xff1a; php 要求&#xff1a;版本在 7.2 版本及以上&#xff1b; 数据库要求&#xff1a;mysql&#xff1a;5.5.62 及以上&#xff1b; mariadb&#xff1a;10.0.63 及以上&#xff1b; 不再支持 IBM DB2 数据库&#xff1b; 不再支…

【云原生】Kubernetes基础命令合集

目录 引言 一、命令概述 &#xff08;一&#xff09;命令分类 &#xff08;二&#xff09;基本语法 二、查看基本信息 &#xff08;一&#xff09;环境指令 1.查看版本信息 2.查看资源对象简写 3.添加补全信息 4.查看日志 5.查看集群信息 &#xff08;二&#xff0…

JDK7HashMap的并发死链问题

测试代码 注意 要在 JDK 7 下运行&#xff0c;JDK7以后否则扩容机制和 hash 的计算方法都变了 JDK7是头插法(死链产生原因)&#xff0c;JDK8是尾插法。 public static void main(String[] args) {// 测试 java 7 中哪些数字的 hash 结果相等System.out.println("长度为…

Linux中解决普通用户使用不了sudo问题

目录 sudo的使用场景sudo使用不了的原因解决方法 sudo的使用场景 之前我们介绍了文件的权限问题 如果一个普通用户想去执行一个它命令之外的权限&#xff0c;只能使用sudo 比如普通用户使用yum去安装软件&#xff0c;需要sudo yum xxxx sudo使用不了的原因 这里我们用普通用户…

Flyway SpringBoot中使用

Flyway 一、 介绍 通过版本化数据库&#xff0c;提高数据库迁移的可靠性。即启动项目时就按版本执行sql脚本&#xff0c;实现数据库自动迁移。 Flyway是一款开源的数据库版本管理工具&#xff0c;它能够实现数据库迁移和版本控制。Flyway通过SQL脚本或Java代码进行数据库变更…

Steam致富:玩免费游戏Banana获得可交易道具

最近&#xff0c;Steam平台上一款普普通通的免费游戏《Banana》引起了轰动&#xff0c;接近2万人同时在线&#xff0c;好评率高达94&#xff05;&#xff0c;究竟是什么让这款游戏如此受欢迎呢&#xff1f;原来&#xff0c;玩家们都在争相获取稀有的香蕉。 《Banana》属于点击放…

说说什么是AOP,以及AOP的具体实现场景(外卖中应用)

推荐B站&#xff1a;【Spring AOP】实际开发中到底有什么用&#xff1f;_哔哩哔哩_bilibili 一、AOP的原理 AOP即Aspect Oriented Program&#xff0c;面向切面编程&#xff0c;是面向对象编程(OOP)的一种增强模式&#xff0c;可以将项目中与业务无关的&#xff0c;却为业务模…

新一代开源爬虫平台:SpiderFlow

SpiderFlow&#xff1a;新一代爬虫平台&#xff0c;以图形化方式定义爬虫流程&#xff0c;不写代码即可完成爬虫。- 精选真开源&#xff0c;释放新价值。 概览 Spider-Flow是一个开源的、面向所有用户的Web端爬虫构建平台&#xff0c;它使用Java语言编写。该平台的核心优势在于…

微信小程序 - - - - - 使用TDesign库(微信小程序UI库)

使用TDesign库 1. 初始化依赖2. 安装TDesgin3. npm构建3. 修改 app.json 1. 初始化依赖 npm init -y2. 安装TDesgin yarn add tdesign-miniprogram -S --productionor npm install tdesign-miniprogram -S --production3. npm构建 3. 修改 app.json 将 app.json 中的 “styl…

docker 挂载运行镜像

文章目录 前言docker 挂载运行镜像1. 作用2. 命令3. 测试 前言 如果您觉得有用的话&#xff0c;记得给博主点个赞&#xff0c;评论&#xff0c;收藏一键三连啊&#xff0c;写作不易啊^ _ ^。   而且听说点赞的人每天的运气都不会太差&#xff0c;实在白嫖的话&#xff0c;那欢…