自己设计函数,实现求根号。x是非负整数。
Input: 8
Output: 2
当开出根号后有小数,则省略小数部分。。
思路:只要找到一个数a,a*a<=x而且(a+1)*(a+1)>x,则a就是开根号后的结果。
这里要注意:a*a因为<=x,不会溢出,但是(a+1)*(a+1)则可能会导致溢出。一种解法就是将两者结果比较,后者小于前者,说明后者溢出了(则后者应该肯定大于x),这是返回a就行。还有一种就是改写上面不等式,将乘号除到右边,变成除,就不会出现溢出。见代码
解法1:暴力解法。
public int mySqrt(int x) { if(x==0) return 0; for(int i=1;i<=x;i++){ //防止溢出 if(i<=x/i&&(i+1)>x/(i+1)) return i; } return 0; }
解法二:利用二分查找。
class Solution { public int mySqrt(int x) { if(x==0) return 0; //二分查找 int left=1,right=x; while(left<right){ int mid=(left+right)/2;
//在二分查找中加入一个判断 if(mid<=x/mid&&(mid+1)>x/(mid+1)) return mid; else if(mid>x/mid) right=mid-1; else left=mid+1; } return left; } }