博客
关于我
蓝桥杯四平方和(暴力)
阅读量:354 次
发布时间:2019-03-04

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

1. 问题描述:

四平方和定理,又称为拉格朗日定理:每个正整数都可以表示为至多4个正整数的平方和。 如果把0包括进去,就正好可以表示为4个数的平方和。 

比如: 
5 = 0^2 + 0^2 + 1^2 + 2^2 
7 = 1^2 + 1^2 + 1^2 + 2^2(^符号表示乘方的意思) 
对于一个给定的正整数N,可能存在多种平方和的表示法。 
要求你对4个数排序:0 <= a <= b <= c <= d 
并对所有的可能表示法按 a,b,c,d 为联合主键升序排列,最后输出第一个表示法 

输入

输入存在多组测试数据,每组测试数据输入一行为一个正整数N (N<5000000) 

输出

对于每组测试数据,要求输出4个非负整数,按从小到大排序,中间用空格分开 

样例输入:

5

12
773535

样例输出:

0 0 1 2

0 2 2 2
1 1 267 838

来源:

2. 思路分析:

一开始的时候想到的是递归(可能最近写的递归代码比较多思维惯势了),后面发现超时了,感觉太蠢了其实仔细分析循环就可以解决,而且其中还有几个优化的地方,使用三层循环就可以解决,第四个数字可以使用n减去前面三个数字的平方和判断,不过提交上去还是超时了,NewOline Judge网站提交上去超时,C语言网站部分数据超时。当遇到类似题目的时候如果可以使用循环解决的尽量使用循环解决,如果使用循环处理比较麻烦那么尝试使用递归解决

3. 代码如下:

import mathif __name__ == '__main__':    while True:        n = int(input())        x = int(math.sqrt(n))        f = 0        a = 0        while a * a <= n:            b = a            while a * a + b * b <= n:                c = b                while a * a + b * b + c * c <= n:                    d = int(math.sqrt(n - a ** 2 + b ** 2 - c ** 2))                    if a ** 2 + b ** 2 + c ** 2 + d ** 2 == n:                        print(a, b, c, d)                        f = 1                        break                    c += 1                if f: break                b += 1            if f: break            a += 1

 

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

你可能感兴趣的文章
JDK 内置线程池
查看>>
JVM 参数默认值查询
查看>>
SVN 和 Git 区别
查看>>
JDK 内置的多线程协作工具类的使用场景
查看>>
Java 源代码到运行的过程
查看>>
Java 中哪些对象可以获取类对象
查看>>
linux 的 cp 命令如何复制不提示覆盖
查看>>
缓存穿透 / 缓存击穿 / 缓存雪崩 / 缓存一致性
查看>>
linux 的 sleep 命令
查看>>
js 的 let var const 区别
查看>>
vue计算属性和监听器区别
查看>>
前端常用知识随手记
查看>>
11.2.6 时间值的小数秒
查看>>
11.2.7 日期和时间类型之间的转换
查看>>
redis 内存溢出_从数据存储的角度告诉你Redis为什么这么快!
查看>>
实例分析Facebook激励视频广告接入
查看>>
实例:使用OKGO下载网络压缩包资源,然后解压缩放在本地使用
查看>>
解决mybatis嵌套查询使用PageHelper分页不准确
查看>>
Redis源码分析(七)--- zipmap压缩图
查看>>
大规模集群自动化部署工具--Chef的安装部署
查看>>