四平方和定理,又称为拉格朗日定理:
每个正整数都可以表示为至多 4 个正整数的平方和。
如果把 0 包括进去,就正好可以表示为 4 个数的平方和。
比如:
5 = 0^2 + 0^2 + 1^2 + 2^2;
7 = 1^2 + 1^2 + 1^2 + 2^2;
对于一个给定的正整数,可能存在多种平方和的表示法。
要求你对 4 个数排序:
0≤a≤b≤c≤d
并对所有的可能表示法按 a,b,c,d 为联合主键升序排列,最后输出第一个表示法。
程序输入为一个正整数 N (N<5×10^6)。
要求输出 4 个非负整数,按从小到大排序,中间用空格分开
输入
12
输出
0 2 2 2
因为N的取值范围较大,(N<5×10^6),我们想到最简单的方法可能是直接四层循环嵌套的暴力解法,但是这样的的解法只能通过N值范围较小的样例,N值较大的样例就会超时,因此我们要想出更加优化的解决方法,尽可能的去降低时间复杂度

import sys
from math import sqrt
n=int(input())
for i in range(int(sqrt(n))+1):for j in range(i,int(sqrt(n-i*i))+1):for k in range(j,int(sqrt(n-i*i-j*j))+1):l=sqrt(n-i*i-j*j-k*k)if l
使用时需引入math库,用来求算数平方根,也就是开方
调用exit函数,终止Python程序
exit(num)
| num | 程序退出类型,整型参数 | 可省略的参数。通常情况下0表示程序正常退出,1表示程序遇到了某个错误而导致退出。实际运用中可以使用任何整型数据,表示不同的自定义错误类型。 |
上一篇:福建名胜古迹的对联