leetcode之sqrt(x)
2016-03-13 10:20
363 查看
题目:
Implement
Compute and return the square root of x.
解答:
首先看到x是int类型,可知sqrt(x)是有取值范围的,然后在这个范围中进行二分查找即可
class Solution {
public:
int mySqrt(int x) {
if(x <= 0)
return 0;
long long int l = 1;
long long int r = 60000;//注意平方后可能会超过int型表示范围,所以需要用long long类型
while(l <= r)
{
long long int mid = (r - l) / 2 + l;
if(mid * mid < x)
{
if((mid + 1) * (mid + 1) > x)
return mid;
else
l = mid + 1;
}
if(mid * mid == x)
return mid;
if(mid * mid > x)
r = mid - 1;
}
}
};
Implement
int sqrt(int x).
Compute and return the square root of x.
解答:
首先看到x是int类型,可知sqrt(x)是有取值范围的,然后在这个范围中进行二分查找即可
class Solution {
public:
int mySqrt(int x) {
if(x <= 0)
return 0;
long long int l = 1;
long long int r = 60000;//注意平方后可能会超过int型表示范围,所以需要用long long类型
while(l <= r)
{
long long int mid = (r - l) / 2 + l;
if(mid * mid < x)
{
if((mid + 1) * (mid + 1) > x)
return mid;
else
l = mid + 1;
}
if(mid * mid == x)
return mid;
if(mid * mid > x)
r = mid - 1;
}
}
};
相关文章推荐
- 只有程序员看的懂的面试圣经|如何拿下编程面试
- 下一次技术面试时要问的 3 个重要问题
- 书评:《算法之美( Algorithms to Live By )》
- 动易2006序列号破解算法公布
- Ruby实现的矩阵连乘算法
- C#插入法排序算法实例分析
- PHP程序员面试 切忌急功近利(更需要注重以后的发展)
- 超大数据量存储常用数据库分表分库算法总结
- C#数据结构与算法揭秘二
- C#冒泡法排序算法实例分析
- 算法练习之从String.indexOf的模拟实现开始
- C#算法之关于大牛生小牛的问题
- C#实现的算24点游戏算法实例分析
- c语言实现的带通配符匹配算法
- 浅析STL中的常用算法
- 算法之排列算法与组合算法详解
- C++实现一维向量旋转算法
- Ruby实现的合并排序算法
- C#折半插入排序算法实现方法
- 基于C++实现的各种内部排序算法汇总