LeetCode 367. 有效的完全平方数
LeetCode 367. 有效的完全平方数
思路:
核心为最后一步判断当二分结束后值为及接近一个整数的浮点数(如2.9xxxx)此时加上极小数(1e-6)取整再平方,若与num相等则为完全平方数
class Solution {
public:
bool isPerfectSquare(int num) {
if (num == 0) return true;
if (num == 1) return true;
double l = 0, r = num;
while (r - l > 1e-6) {
double mid = (l + r) / 2;
if (mid * mid == num) return true;
else if (mid * mid > num) r = mid;
else l = mid;
}
int y = (int)(l + 1e-6);
if (y * y == num) return true;
return false;
}
};
分类:
LeetCode刷题
, 二分
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 全程不用写代码,我用AI程序员写了一个飞机大战
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!