LeetCode-69题.sqrt(x)

本文介绍两种求解整数平方根的方法:暴力查找法与二分查找法。暴力查找法通过遍历所有可能来找到最接近的平方根;二分查找法则利用对数时间复杂度的优势快速定位结果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

暴力查找法:

class Solution {
public:
    int mySqrt(int x) {
        int squareroot;
        for(long int i = 0; i <= x; i++){
            if(i*i == x){
                squareroot = i;
                break;
            }else if(i*i  > x){
                if((i-1)*(i-1) < x){
                    squareroot = i-1;
                    break;
                }  
            }
        }
        return squareroot;
    }
};

 二分查找法:

class Solution {
public:
    int BinarySearch(int left, int right, int x){
        long int mid = (left + right) / 2;
        if(mid * mid == x){
            return mid;
        }else if(left + 1 == right){
            return left;
        }
        
        if(x > mid * mid)
            return BinarySearch(mid, right, x);
        else
            return BinarySearch(left, mid, x);        
    }
    int mySqrt(int x) {
        if(x == 0)
            return 0;
        if(x == 1)
            return 1;
        
        long int temp = 1;
        while(temp*temp < x){
            temp = temp * 10;
        }
        
        return BinarySearch(temp/10, temp, x);
    }
};

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值