力扣69 x的平方根 二分查找求平方根 C语言

news/2024/9/24 0:25:33/

题目

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

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

注意:不允许使用任何内置指数函数和算符,例如 pow(x, 0.5) 或者 x ** 0.5 。

示例 1:

输入:x = 4
输出:2

示例 2:

输入:x = 8
输出:2
解释:8 的算术平方根是 2.82842..., 由于返回类型是整数,小数部分将被舍去。

思路

从评论里看到一位大佬用的二分查找,自己想不到这样做,记录一下。其中判断 x 是否大于等于mid的平方时,用的是 x/mid >= mid,这样来防止溢出。真妙啊!

代码

int mySqrt(int x) {if(x == 1)return 1;int min = 0;int max = x;while(max - min > 1){int mid = (min + max) / 2;if(x/mid >= mid)min = mid;elsemax = mid;}return min;
}


http://www.ppmy.cn/news/1455880.html

相关文章

Gradle基础学习(七) 认识插件

Gradle构建在一个插件系统上,本身主要由基础设施组成,比如有一个先进的依赖解析引擎,而其他功能则来自插件。 插件是提供额外功能给Gradle构建系统的软件组件。 插件可以被应用到Gradle构建脚本中,以添加新的任务、配置或其他与构…

【Unity】如何获得两个List各自的补集

【背景】 在项目中需要处理这样的逻辑,将所有活跃客户端的IP地址形成一个IP地址列表,与项目中已经生成按钮实例的IP按钮进行比照,如果某一个IP处于活跃状态,但是并未生成实例按钮,那么就生成实例。如果一个按钮的IP地址不存在于当前的IP地址列表中,则需要销毁这个Button…

力扣刷题:四数相加Ⅱ

题目详情: 解法一:暴力枚举 对于这道题,我们的第一思路就是暴力枚举,我们可以写一个四层的for循环进行暴力匹配,只要相加的结果等于0就进行统计。但是我们会发现,我们的事件复杂度为O(N^4)事件复杂度非常大…

【智能算法应用】麻雀搜索算法求解非线性方程组问题

目录 1.算法原理2.数学模型3.结果展示4.代码获取 1.算法原理 【智能算法】麻雀搜索算法(SSA)原理及实现 2.数学模型 非线性方程组为: 2 x 1 − x 2 e − x 1 − x 1 2 x 2 e − x 2 (1) \begin{aligned}&2x_1-x_2e^{-x_1}\\&-…

java学习记录最后一篇

面向对象编程 封装 该露的露,该藏的藏 我们程序设计要追求“高内聚,低耦合”。高内聚就是类的内部数据细节由自己完成,不允许外部干涉;低耦合:仅暴露少量的方法给外部使用。 封装(数据的隐藏&#xff0…

NIO BIO AIO详解

BIO: 同步阻塞I/O,是JDK1.4之前的传统IO模型。 线程发起IO请求后,一直阻塞,直到缓冲区数据就绪后,再进入下一步操作。 NIO:同步非阻塞IO,当线程发起IO请求后,不需要阻塞,会立即返回。用户线程不…

【易错题】第三章-数据库应用(SQL)#CDA Level 1

本文整理了CDA Level 1 数据库应用相关的易错题,来源:如荷学题库CDA Level 1(第三章模拟题一至四)。 第三章 数据库应用 1)数据类型 2)表/列别名 3)聚合函数 4)完整性约束 5&#x…

C++入门——基本概念与关键字(上)

兜兜转转终于来到C的学习,C作为一种更高级的语言,是在C的基础之上,容纳进去了面向对象编程思想,并增加了许多有用的库,以及编程范式,本节笔者旨在带领读者理解C是如何对C语言设计不合理的地方进行优化的&am…