博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
leetcode:279 四平方数和(math)
阅读量:4060 次
发布时间:2019-05-25

本文共 731 字,大约阅读时间需要 2 分钟。

任何正整数都可以表示为四个平方数之和。

4平方数情况:n = 4^k * ( 8*b + 7 )
2平方数情况:n = 4^k * ( a*a + b*b )
1平方数情况:n = 4^k * ( a*a )
3平方数情况:其他

class Solution {public:    int numSquares(int n) {        while( (n&3) == 0) n/=4;        if( (n&7) == 7) return 4;        int a = 0;        const double eps = 0.000001;        while(a*a < n){            int b = int(sqrt(n-a*a) + eps);            if( a*a + b*b == n){                if(a != 0 && b != 0){                    return 2;                }else{                    return 1;                }            }            a++;        }        return 3;    }};

一个很强的公式:

(a^2 + b^2 + c^2 + d^2)* (x^2 + y^2 + z^2 + w^2)  = (ax + by + cz + dw)^2 + (ay - bx + cw -dz)^2 + (az - bw -cx + dy)^2 + (aw + bz - cy - dx)^2

转载地址:http://efwji.baihongyu.com/

你可能感兴趣的文章
JVM并发机制探讨—内存模型、内存可见性和指令重排序
查看>>
nginx+tomcat+memcached (msm)实现 session同步复制
查看>>
WAV文件解析
查看>>
WPF中PATH使用AI导出SVG的方法
查看>>
QT打开项目提示no valid settings file could be found
查看>>
Win10+VS+ESP32环境搭建
查看>>
android 代码实现圆角
查看>>
flutter-解析json
查看>>
android中shader的使用
查看>>
java LinkedList与ArrayList迭代器遍历和for遍历对比
查看>>
drat中构造方法
查看>>
JavaScript的一些基础-数据类型
查看>>
ReactNative使用Redux例子
查看>>
Promise的基本使用
查看>>
coursesa课程 Python 3 programming 统计文件有多少单词
查看>>
course_2_assessment_6
查看>>
coursesa课程 Python 3 programming course_2_assessment_7 多参数函数练习题
查看>>
coursesa课程 Python 3 programming course_2_assessment_8 sorted练习题
查看>>
在unity中建立最小的shader(Minimal Shader)
查看>>
1.3 Debugging of Shaders (调试着色器)
查看>>