Java | Leetcode Java题解之第279题完全平方数

题目:

题解:

java 复制代码
class Solution {
    public int numSquares(int n) {
        if (isPerfectSquare(n)) {
            return 1;
        }
        if (checkAnswer4(n)) {
            return 4;
        }
        for (int i = 1; i * i <= n; i++) {
            int j = n - i * i;
            if (isPerfectSquare(j)) {
                return 2;
            }
        }
        return 3;
    }

    // 判断是否为完全平方数
    public boolean isPerfectSquare(int x) {
        int y = (int) Math.sqrt(x);
        return y * y == x;
    }

    // 判断是否能表示为 4^k*(8m+7)
    public boolean checkAnswer4(int x) {
        while (x % 4 == 0) {
            x /= 4;
        }
        return x % 8 == 7;
    }
}
相关推荐
途经六月的绽放3 分钟前
常见设计模式及其应用示例
java·设计模式
REI-4 分钟前
黑马点评项目启动
java·后端
AlunYegeer11 分钟前
【JAVA】网关的管理原理和微服务的Interceptor区分
java·服务器·前端
Mr_Xuhhh15 分钟前
LeetCode 热题 100 刷题笔记:高频面试题详解(215 & 347)
算法·leetcode·排序算法
童话ing24 分钟前
【LeetCode】239.滑动窗口最大值
数据结构·算法·leetcode·golang
xieliyu.27 分钟前
Java、抽象类
java·开发语言
我真会写代码28 分钟前
SpringBoot自动装配原理:告别繁琐配置,读懂底层逻辑
java·spring boot·mybatis
happymaker062632 分钟前
servlet、jsp、请求转发、重定向的一些个人理解
java·开发语言·servlet
于先生吖34 分钟前
国际版答题系统 JAVA 源码实战指南
java·开发语言
gelald1 小时前
JVM - 垃圾回收
java·jvm·后端