Python每日练习—2020.2.21

Python练习—完全平方数

【问题描述】 一个整数,它加上100后是一个完全平方数,再加上168又是一个完全平方数,请问该数是多少?

初步代码实现:

import math
num = 0
while True:
    if math.sqrt(num + 100) == int(math.sqrt(num + 100)) and math.sqrt(num + 268) == int(math.sqrt(num + 268)):
            print(num)
    num += 1

事实上这个代码是没有截至的,因为没有设置限制,而且num从0开始,没有考虑到负数,所以这个代码还是有缺陷的
改进:最坏的结果是n的平方与(n+1)的平方刚好差168,由于是平方的关系,不可能存在比这更大的间隙。

import math
num = 0
while (num+1)**2-num*num <= 168:
    num += 1
for i in range((num+1)**2):
    if math.sqrt(i) == int(math.sqrt(i)) and math.sqrt(i+168) == int(math.sqrt(i+168)):
        print(i-100)

这样的话,负数也就可以输出

全部评论

相关推荐

10-14 23:01
已编辑
中国地质大学(武汉) Java
CUG芝士圈:虽然是网上的项目,但最好还是包装一下,然后现在大部分公司都在忙校招,十月底、十一月初会好找一些。最后,boss才沟通100家,别焦虑,我去年暑假找第一段实习的时候沟通了500➕才有面试,校友加油
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务