Python:每日一题之四平方和
创始人
2024-02-15 16:04:33
0

题目描述

四平方和定理,又称为拉格朗日定理:

每个正整数都可以表示为至多 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

sqrt()函数

使用时需引入math库,用来求算数平方根,也就是开方

exit()函数

调用exit函数,终止Python程序

语法

exit(num)
num程序退出类型,整型参数可省略的参数。通常情况下0表示程序正常退出,1表示程序遇到了某个错误而导致退出。实际运用中可以使用任何整型数据,表示不同的自定义错误类型。

 注意:

  1. int(sqrt(n))+1 是向下取,例如里面的值如果是3.99,会取3,所以后面要加 1
  2. int(l)==l 这里是用来判断 l (L)是否为整数
  3. if l
  4. 因为exit是sys这个包里的一个函数,你要用别人的工具,就要说一下它来自哪里,所以要sys.exit(0) 这样使用

相关内容

热门资讯

高盛再度唱多!预计中国股市到2... 来源:视觉中国 界面新闻编辑 | 江怡曼 近日,高盛发布名为《中国策略:2025年中国股市十大...
尤文身价变化:共10人身价下降... 在意甲联赛的激烈竞争中,尤文图斯的球员身价变化引发了广泛关注。根据最新的德转数据,尤文队内有10名球...
美国发布H-1B签证新规,优先... 当地时间12月23日,美国国土安全部发布新规,正式以“加权选择”机制取代H-1B签证原有的随机抽签制...
悉尼恐袭事件,意外替德国默茨政... 刚刚过去的一周,发生在澳大利亚的悉尼邦迪海滩恐怖袭击事件引起全球关注。 对于万里之外的德国而言,这场...
视频丨“粤车南下”驶入香港市区... 今天(12月23日),“粤车南下”驶入香港市区政策正式实施,符合条件的广东私家车可直接驶入香港市区,...
立白回应与经销商解约纠纷:个别... 12月23日,红星新闻报道《多地代理商称与立白集团解约后 对方未按约交接市场致严重损失,律师解读》一...
原创 宁... 据北京日报报道,12月中下旬的东亚地缘舞台格外热闹,日本首相高市早苗的一系列外交动作让外界看得眼花缭...
原创 阿... ATP针对大师赛和500赛事稳定参赛所设立的奖金,金额已可与大满贯奖金相媲美。目前的奖金榜显示,阿尔...
长春一女子打车遇“最炫出租车”... 极目新闻记者 王柳钦 近日,有网友发视频称,她和朋友在吉林长春乘坐出租车时,意外坐上了一辆改装有绚丽...
一次性信用修复政策落地,消金公... 一次性信用修复政策重磅落地,12月22日,中国人民银行发布一次性信用修复政策:明确对特定时期、特定金...