当前位置:网站首页>x 的平方根
x 的平方根
2022-07-26 22:42:00 【咖啡不加冰和糖】
题目描述
实现 int sqrt(int x) 函数。
计算并返回 x 的平方根,其中 x 是非负整数。
由于返回类型是整数,结果只保留整数的部分,小数部分将被舍去。
思路分析
x的平方根的范围在1~x/2之间,所以我们可以用双指针解题:
- lower = 1;high = x/2; mid = lower + (high - lower) / 2;
- 判断:
mid * mid == x=>return mid; mid * mid < x=>lower = mid + 1;mid * mid > x=>high = mid - 1;- 循环结束条件:
lower > high;
参考代码
public int mySqrt(int x) {
if(x <= 1)return x;
int lower = 1;
int high = x / 2;
while(lower <= high){
int mid = lower + (high - lower) / 2;
if((long) mid * mid == x)return mid;
else if((long) mid * mid < x)lower = mid + 1;
else high= mid - 1;
}
return high;
}
注意:
最后的返回值的确定:当 lower== high == mid 时,无非3种情况:
- mid * mid == x; return high;
- mid * mid < x; lower = mid + 1; 此时 lower > high,返回high;
- mid * mid > x; high = mid - 1; 此时 lower > high,返回high;
因为最后 high <= lower,所以返回high,
边栏推荐
- 李宏毅机器学习(2017版)_P3-4:回归
- C # conversion of basic data types for entry
- Use and cases of partitions
- Neo4j基础指南(安装,节点和关系数据导入,数据查询)
- 李宏毅机器学习(2021版)_P7-9:训练技巧
- Solve the problem of direct blue screen restart when VMware Workstation virtual machine starts
- SparkSql之DataFrame
- 深度学习汇报(2)
- Simple explanation of database table connection
- 解决rsyslog服务占用内存过高
猜你喜欢

flinksql 窗口提前触发

Rabbit学习笔记

Flink1.11 SQL local run demo & local webui visual solution

MTCNN

adb.exe已停止工作 弹窗问题

Flinksql multi table (three table) join/interval join

MYSQL 使用及实现排名函数RANK、DENSE_RANK和ROW_NUMBER

MySQL index optimization: scenarios where the index fails and is not suitable for indexing

Applet live broadcast, online live broadcast, live broadcast reward: Tencent cloud mobile live broadcast component mlvb multi scene live broadcast expansion

深度学习报告(3)
随机推荐
智密-腾讯云直播 MLVB 插件优化教程:六步提升拉流速度+降低直播延迟
Flink's fault tolerance mechanism (checkpoint)
数据仓库知识点
MySQL8.0中的隐藏索引和降序索引(新特性)
Android -- basic usage of litepal database framework
Flink1.11 intervaljoin watermark generation, state cleaning mechanism source code understanding & demo analysis
李宏毅机器学习(2017版)_P5:误差
Flink sliding window understanding & introduction to specific business scenarios
深度学习汇报(1)
腾讯升级视频号小程序直播功能,腾讯持续推广直播的底气是这项叫视立方(MLVB)的技术
李宏毅机器学习(2017版)_P13:深度学习
基于Flink实时计算Demo:用户行为分析(四:在一段时间内到底有多少不同的用户访问了网站(UV))
分区的使用及案例
Scala-模式匹配
解决Pytorch中Cuda无法GPU加速问题
C # conversion of basic data types for entry
How to open ads for profit after uni app develops apps and plug-ins: uni ad
Write the changed data in MySQL to Kafka through flinkcdc (datastream mode)
Select query topic exercise
flink需求之—ProcessFunction(需求:如果30秒内温度连续上升就报警)