367. 有效的完全平方数
二分查找
class Solution {
public boolean isPerfectSquare(int num) {
int left = 1;
int right = num;
while (left <= right){
int mid = left + (right - left) / 2;
/**
* 避免整形溢出,转换为long
*/
if ((long) mid * mid > num){
right = mid - 1;
}
else if ((long) mid * mid < num){
left = mid + 1;
}
else {
return true;
}
}
return false;
}
}
/**
* 时间复杂度 O(logn)
* 空间复杂度 O(1)
*/
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律