• Python:每日一题之四平方和


    题目描述

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

    每个正整数都可以表示为至多 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值较大的样例就会超时,因此我们要想出更加优化的解决方法,尽可能的去降低时间复杂度

     

    参考代码:

    1. import sys
    2. from math import sqrt
    3. n=int(input())
    4. for i in range(int(sqrt(n))+1):
    5. for j in range(i,int(sqrt(n-i*i))+1):
    6. for k in range(j,int(sqrt(n-i*i-j*j))+1):
    7. l=sqrt(n-i*i-j*j-k*k)
    8. if l
    9. break
    10. if int(l)==l:
    11. print(i,j,k,int(l))
    12. 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
    4. 因为exit是sys这个包里的一个函数,你要用别人的工具,就要说一下它来自哪里,所以要sys.exit(0) 这样使用
  • 相关阅读:
    【ARM Coresight SoC-400/SoC-600 专栏导读】
    2530. 执行 K 次操作后的最大分数
    龙口联合化学通过注册:年营收5.5亿 李秀梅控制92.5%股权
    RabbitMQ的常用命令
    Canny 算法的详解。
    ThreadLocal优化
    配置错误的smb共享
    [buuctf.reverse] 126-130
    Acwing 839. 模拟堆
    【机试题】两个链表相减,并以相同形式返回一个表示相减结果的链表
  • 原文地址:https://blog.csdn.net/qq_65144447/article/details/128042796