Python世界:求解满足某完全平方关系的整数实践

Python世界:求解满足某完全平方关系的整数实践

任务背景

本问题来自于菜鸟教程Python 100例中的例3:

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

实现思路

本文较原问题无改进,仅做实现验证,以助个人理解。

问题分析

假设该整数为x,依据题意可转化为以下公式:
x + 100 = n 2 ( 1 ) x + 100 + 168 = m 2 ( 2 ) x + 100 = n^2 \ \ (1)\\ x + 100 + 168 = m^2 \ \ (2)\\ x+100=n2 (1)x+100+168=m2 (2)

由公式1和2,可推导并转化为以下公式:

( m − n ) ( m + n ) = 168 ( 3 ) i ∗ j = 168 ( 4 ) m = ( i + j ) / 2 ( 5 ) n = ( − i + j ) / 2 ( 6 ) (m - n)(m + n) = 168 \ \ (3)\\ i*j = 168 \ \ (4)\\ m = (i + j) / 2 \ \ (5)\\ n = (-i + j) / 2 \ \ (6)\\ (m−n)(m+n)=168 (3)i∗j=168 (4)m=(i+j)/2 (5)n=(−i+j)/2 (6)

以上推导,目的是为了将数学问题转化为计算机可求解的问题,核心看公式4,时刻注意前提x, m, n, i, j均为整数。

从公式1-2,易知:

  • m, n正负不影响x的结果

从公式3-6,易知:

  • i, j必须均为偶数,且两者同正同负
  • i, j其中最小至少为2
  • i, j其中最大至多为168/2

由此可知,问题简化为i, j均为正整数,i, j遍历区间为[2, 168/2],寻找满足公式4-6的i, j,然后反求x。

参考代码

python 复制代码
# -*- coding: utf-8 -*-
"""
功能:求例3的x值
1、初步分析限定范围
2、限定整数范围内遍历求解
"""

def find_x():
    x = []

    # i, j is even
    upper_bound = 168 // 2 + 1 # 加1目的是因为range左开右闭
    for i in range(2, upper_bound, 2):
        j = 168 // i # `//` 实现整数除法
        if j % 2 == 0:
            is_even = True
        else:
            is_even = False
        if i < j and i * j == 168 and is_even: # i, j地位等价,i>j时只是位置交换,x结果不变,故没必要遍历
            res = int(((i + j) / 2) ** 2 - 268)
            x.append(res)
    return x


if __name__ == '__main__':
    print('start!')

    # 正式运行
    x = find_x()
    print(x)

    # 正式退出main函数进程,以免main函数空跑
    print('done!')

参考资料

  1. python的两种除法/和//,得到的数是整型还是浮点型?
  2. 菜鸟教程Python 练习实例3
相关推荐
西洼工作室2 分钟前
B站登录流程全解析:RSA+极验验证
前端·python·极验
zhaoyong2222 分钟前
如何在 MySQL 中实现基于全字段唯一性的重复行计数更新
jvm·数据库·python
X56614 分钟前
为什么宝塔面板网站无法正常连接外部远程数据库_检查服务器安全组放行端口并开启IP授权
jvm·数据库·python
woxihuan1234568 分钟前
C#怎么使用CancellationToken C#如何用取消令牌优雅地取消异步任务和长时间操作【进阶】
jvm·数据库·python
测试员周周15 分钟前
【AI测试功能5】AI功能测试的“黄金数据集“构建指南:从0到1搭建质量评估体系
运维·服务器·开发语言·人工智能·python·功能测试·集成测试
yexuhgu18 分钟前
MySQL主从复制支持跨版本吗_不同版本间同步的注意事项
jvm·数据库·python
好运的阿财21 分钟前
7天没有打开OpenClaw了
python·机器学习·ai·ai编程·openclaw
蓝眸少年CY24 分钟前
Scala - 基础教程
开发语言·后端·scala
woxihuan12345624 分钟前
CSS怎样调整弹性项目排列顺序_使用order属性轻松控制DOM显示顺序
jvm·数据库·python
卡次卡次125 分钟前
14.2:详细补充:子进程会复制什么
前端·python·php