Python:每日一题之四平方和

本文探讨如何利用数学技巧优化求解四平方和定理的问题,针对大数范围提供高效的解决方案,避免暴力嵌套带来的超时问题。讲解了如何利用平方根计算和条件判断减少复杂度,适用于正整数N小于5*10^6的情况。

题目描述

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

每个正整数都可以表示为至多 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<k:
              break
            if int(l)==l:
              print(i,j,k,int(l))
              sys.exit(0)

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<k:break  因为i j k l 是依次增大的,若不是则结束此次循环
  4. 因为exit是sys这个包里的一个函数,你要用别人的工具,就要说一下它来自哪里,所以要sys.exit(0) 这样使用
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

努力的敲码工

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值