面试-Sqrt(x)

news2024/10/6 20:32:41

题目

给你一个非负整数 x ,计算并返回 x 的 算术平方根 。

由于返回类型是整数,结果只保留 整数部分 ,小数部分将被 舍去 。

注意:不允许使用任何内置指数函数和算符,例如 pow(x, 0.5) 或者 x ** 0.5 。
在这里插入图片描述

思路

二分查找

因为题目中说了,结果只保留整数的部分,小数部分将被舍去

即:问题的答案,平方以后一定不会严格大于输入的整数,如8的平方根实际上是 2.82842,题目要求将小数部分舍去,因此输出 2,如果返回3,则3^2 = 9 > 8就不对了

这其实是一个查找整数的问题,并且这个整数是有范围

(1)如果这个整数的平方 恰好等于 输入整数,那么就找到了这个整数
(2)如果这个整数的平方 严格大于 输入整数,那么这个整数肯定不是要找的那个数,大了就往小的猜
(3)如果这个整数的平方 严格小于 输入整数,那么这个整数 可能 是要找的那个数

另外一个整数的平方根肯定不会超过(<=)它自己的一半,但是 0 和 1 除外,因此可以在 1 到输入整数除以 2 这个范围里查找要找的平方根整数,0单独判断一下即可

class Solution {
    public int mySqrt(int x) {
        // 特殊值判断
        if (x == 0) {
            return 0;
        }
        if (x == 1) {
            return 1;
        }
        int left = 1;
        int right = x / 2;
        while (left < right) {
            int mid = left + (right - left + 1)  / 2;//有特殊测试用例,这里mid不加1会死循环
            // 注意:这里为了避免乘法溢出,改用除法
            if (mid > x / mid) {
                // 下一轮搜索区间是 [left..mid - 1],因为大于x一定不对,不用再取mid了
                right = mid - 1;
            } else {
                // 下一轮搜索区间是 [mid..right],保证和上一个区间连起来是一个完整区间
                left = mid;//如果是小于x,mid仍然可能是答案,所以要算上
            }
        }
        return left;
    }
}

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

项目管理:项目进度难以把控,项目经理应该怎么办?

项目管理中&#xff0c;对进度的管理也是保障整个项目顺利完成的重要条件。项目进度难以把控&#xff0c;项目常常延期&#xff0c;项目经理怎么办&#xff1f;如何跟进整个项目的进度&#xff1f; 对于如何做好项目进度管理&#xff0c;有几点建议&#xff0c;希望能对大家有…

Java实现导出多个excel表打包到zip文件中,供客户端另存为窗口下载

文章目录一、业务背景二、实现思路二、准备工作1.准备data模板.xlsx2.引入poi相关依赖&#xff0c;用于操作excel3.针对WorkBookZIP压缩输入/输出流&#xff0c;相关方法知识点要有所了解三、完整的项目代码四、可能遇到的问题错误场景1&#xff1a;java.io.IOException: Strea…

【RabbitMQ】SpringBoot整合RabbitMQ实现延迟队列、TTL、DLX死信队列

目录 一、TTL 1、什么是TTL 2、设置TTL的两种方式 3、控制台设置TTL 4、SpringBoot实现两种方式设置TTL 1.给消息设置过期时间 2.给队列设置过期时间 二、DLX死信队列 1、什么是死信交换机与死信队列 2、消息何时会成为死信 3、队列如何绑定死信交换机与死信队列 4…

vscode“检测到 #include 错误,请更新 includepath。”的问题解决办法

目录 一.报错更新includepath​编辑 二.原因 三.解决方法 一.报错更新includepath 如图 二.原因 1.没有安装gcc 2.没有配置好环境 winR打开cmd,输入gcc -v,如果安装了gcc,会返回版本 三.解决方法 1.安装MinGW 2.添加MinGW环境变量 将bin文件夹的位置添加到系统环境变量中…

三分钟搭建个人博客技术栈Nuxt3+vite+mysql+koa2

最近也是想入一下Nuxt3的坑&#xff0c;然后就写了一个博客系统&#xff0c;目前已开源github&#xff0c;欢迎大家star&#xff01;&#xff01;&#xff01; 效果预览 网址&#xff1a;http://180.76.121.2:3000/ github地址 https://github.com/ztzzhi/ztzzhi-nuxt3-vite…

MySQL事物(基础篇)

MySQL事务事物的基本概念事物的ACID属性事务的使用事务隔离级别MVCC&ReadViewMySQL是否还存在幻读事物的基本概念 Transaction作为关系型数据库的核心组成&#xff0c;在数据安全方面有着非常重要的作用&#xff0c;本文会一步步解析事务的核心特性&#xff0c;以获得对事…

多云数据存储,理想与现实之间还差着什么?

去年底&#xff0c;“数据二十条”正式颁布&#xff0c;数据要素全面提速已是指日可待。 无疑&#xff0c;数据作为数字经济的基础&#xff0c;其价值的释放依赖于数据的流动、共享和应用。数据要素只有充分地流动和应用起来&#xff0c;才能够实现价值的最大化。 换而言之&a…

VPN、IPSEC、AH、ESP、IKE、DSVPN

目录 1.什么是数据认证&#xff0c;有什么作用&#xff0c;有哪些实现的技术手段? 2.什么是身份认证&#xff0c;有什么作用&#xff0c;有哪些实现的技术手段? 3.什么VPN技术? 4. VPN技术有哪些分类? 5. IPSEC技术能够提供哪些安全服务? 6. IPSEC的技术架构是什么?…

idea中使用git工具

目录一、IDEA中配置git二、git操作将项目设置成git仓库一、IDEA中配置git 打开idea&#xff0c;点击File–>Settings 点击版本控制&#xff0c;然后点击git 将你的git.exe安装目录填到下面位置 点击test可以看到显示了版本&#xff0c;说明配置成功 二、git操作 将项目设置…

geoserver更换默认的端口、修改默认密码

geoserver默认的端口是8080,有的时候会与其他的项目相冲突,我们的目标是将端口修改为8888,如何更改呢?geoserver正常安装的默认用户名密码为admin/geoserver,如何做一个修改呢将默认密码修改为其他的。 修改端口 分两种情况: (一)如果安装的时候,指定了端口,修改s…

elasticsearch基础教程

elasticsearch安装 有些软件对于安装路径有一定的要求&#xff0c;例如&#xff1a;路径中不能有空格&#xff0c;不能有中文&#xff0c;不能有特殊符号&#xff0c;等等。 为了避免不必要的麻烦&#xff0c;也懒得一一辨别踩坑&#xff0c;我们人为作出「统一的约定」&…

2023_深入学习HTML5

H5 基于html5和 css3和一部分JS API 结合的开发平台(环境) 语义化标签 header : 表示头部&#xff0c;块级元素 footer &#xff1a; 表示底部&#xff0c;块级元素 section &#xff1a;区块 nav &#xff1a; 表示导航链接 aside &#xff1a; 表示侧边栏 output &am…

Flume系列:Flume组件架构

目录 Apache Hadoop生态-目录汇总-持续更新 一&#xff1a;Flume 概述 二&#xff1a;Flume 基础架构 2.1&#xff1a;Agent 2.2&#xff1a;Source 2.3&#xff1a;Sink 2.4&#xff1a;Channel 1) Memory Channel 2) File Channel 3) Kafka Channel 2.5&#xff1a…

AI 绘画 API 超详细使用教程 - 附微信小程序接入代码

写在前面 【AI绘画/AI图像生成】已成为现下炙手可热的话题&#xff0c;AI 大模型训练的成本高昂&#xff0c;算法研究时间周期较长&#xff0c;对于大多数人来说&#xff0c;自研一套算法模型还是非常困难的&#xff0c;因此 AI 绘画 API 就应运而生&#xff0c;直接调用 AI 绘…

MRI图像配准技术及其未来

前言 早在20世纪40年代数字革命开始之前&#xff0c;图像配准就已经成为一个具有重要现实意义的过程。这技术首次应用于彩印&#xff0c;即将几种单色图案叠加在一起形成多色图案。为了生成最终所需的多色印刷品&#xff0c;各个层相对于另一个层的对齐必须是精确的。若个别层…

linux PAM模块简介

PAM模块简介1. 介绍1.1 概念1.2 验证过程简述2. 配置文件介绍2.1 PAM的模块类型2.2 PAM的控制标记2.3 PAM的模块路径3. 验证机制3.1 login的验证机制流程3.2 pam相关文件4. 示例4.1 ssh远程登录控制4.2 禁止账号间使用su命令切换4.3 限制root从tty1,tty2&#xff0c;tty5登录1.…

墨菲安全入选网络安全全景图,将持续深耕软件供应链安全垂直领域

2023年4月7日&#xff0c;中国网络安全领域的专业媒体安全牛正式发布第十版网络安全行业全景图&#xff0c;展现了我国网络安全行业的应用发展与变革创新&#xff0c;所有申请企业通过多个维度审核考量。墨菲安全作为一家专注于软件供应链安全领域的创新企业&#xff0c;以开发…

数据层的解决方案(NOSQL)

1.Redis 1.Redis是一款key-value存储结构的内存结构的内存级NoSQL数据库 支持多种数据存储 支持持久化 支持集群 2.服务器的启动命令&#xff1a; redis-server.exe redis.windows.conf 3.客户端启动命令 redis-cli.exe 4.SpringBoot整合Redis 1.导入相应的依赖 <…

ESP32学习笔记09-ADC多通道采集 dma方式传输

9. ADC多通道采集 dma方式传输 9.1 DIG SAR ADC 控制器 9.1.1特点 高性能。时钟更快,因此采样速率实现了大幅提升。支持多通道扫描模式。每个 SAR ADC 的测量规则可见样式表。扫描模式可配置为 单通道模式双通道模式交替模式。扫描可由软件或 I2S 总线发起。支持 DMA,扫描完…

Win10 安装配置 Hadoop 及 Spark

以下内容只针对 Win10 系统 1. 环境安装 (1) 安装Java并配置环境变量 https://www.oracle.com/java/technologies/downloads/#java8-windows (2) 安装Scala https://www.scala-lang.org/ 或 https://github.com/lampepfl/dotty/releases/tag/3.2.2 配置环境变量&#xff0…