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;
    }
}
相关推荐
咖啡八杯41 分钟前
GoF设计模式——单例模式
java
0xDevNull42 分钟前
JDK多版本切换安装与配置
java·后端
流年似水~44 分钟前
Java新手5分钟接AI:Spring AI Alibaba实战
java·人工智能·spring
DarkAthena1 小时前
【YaShanDB】给YaShanDB开发R2DBC驱动
java·yashandb·r2dbc
014-code1 小时前
布隆过滤器:判断“可能存在“和“一定不存在“
java·redis
兔小盈1 小时前
多线程篇-(二)线程创建、中断与终止
java·开发语言·多线程
jnrjian1 小时前
Library Cache Load Lock library cache pins are replaced by mutexes
java·后端·spring
abcnull2 小时前
传统的JavaWeb项目Demo快速学习!
java·servlet·elementui·vue·javaweb
risc1234562 小时前
【lucene】PostingsEnum跟TermsEnum 的区别是啥?
java·lucene