蓝桥杯刷题-四平方和

四平方和

代码:

python 复制代码
from copy import deepcopy
n = int(input())
maxn = int(5e6) + 10
dic = dict()
for a in range(maxn):
    if a * a > n:
        break
    for b in range(a,maxn):
        if a * a + b * b > n:
            break
        if dic.get(a*a+b*b) is None:
            dic[a*a+b*b] = (a,b)
ans = [maxn for _ in range(4)]
for a in sorted(dic.keys()):
    b = n - a
    if a > b:
        break
    if b in dic.keys():
        tmp = list(dic[a]+dic[b])
        tmp.sort()
        for i in range(4):
            if tmp[i] != ans[i]:
                if tmp[i] < ans[i]:
                    ans = deepcopy(tmp)
                break
for i in range(3):
    print(ans[i], end = ' ')
print(ans[-1])

作者:波尔k
链接:https://www.acwing.com/activity/content/code/content/8139085/
来源:AcWing
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
相关推荐
aini_lovee3 分钟前
严格耦合波(RCWA)方法计算麦克斯韦方程数值解的MATLAB实现
数据结构·算法·matlab
安特尼20 分钟前
推荐算法手撕集合(持续更新)
人工智能·算法·机器学习·推荐算法
weixin_4572971023 分钟前
大数据面试常见问题
大数据·面试·职场和发展
白云千载尽26 分钟前
LQR与MPC.入门知识与实验
python·控制·mpc·lqr
鹿角片ljp26 分钟前
力扣14.最长公共前缀-纵向扫描法
java·算法·leetcode
weixin_4331793327 分钟前
Hangman 猜字游戏使用列表List实现
开发语言·python
Remember_99331 分钟前
【数据结构】深入理解优先级队列与堆:从原理到应用
java·数据结构·算法·spring·leetcode·maven·哈希算法
偷星星的贼1131 分钟前
C++中的状态机实现
开发语言·c++·算法
程序员敲代码吗32 分钟前
C++中的组合模式实战
开发语言·c++·算法
52Hz1181 小时前
二叉树理论、力扣94.二叉树的中序遍历、104.二叉树的最大深度、226.反转二叉树、101.对称二叉树
python·算法·leetcode