【每日一练】勾股定理困难版

目录

题目

给定斜边z的值,求所有直角边x和y的组合数(x、y和z都是正整数)。

仅有一行输入,即斜边z的值(z是正整数,且z<10000000000000000000)

输出x和y的组合数(x和y是正整数)

时间限制:1000ms

内存限制:256M

官方给的解题思路

源代码

根据官方思路,编的第一版:

def main(c):
    group = set()
    g_list = get_factor(2*c)
    for g in g_list:
        n = (2*c)/g
        for x1 in range(1, int(n**0.5)+1):
            y1 = (n - x1**2)**0.5
            _y1 = y1 - int(y1)
            if _y1 == 0 and y1 > x1:
                x = g*x1**2
                y = g*y1**2
                a = int((x*y)**0.5)
                b = int(abs(x-y)/2)
                group.add((a, b))
    return len(group)

def get_factor(n):
    r = []
    x = 1
    while x < n:
        if n % x == 0:
            r.append(x)
        x += 1
    return r

if __name__=='__main__':
    z = input()
    nums = main(int(z))
    print(nums)

根据官方思路,编的第二版,修改了计算因数部分的代码,代码通过~

def main(c):
    group = set()
    g_list = get_factor(2*c)
    for g in g_list:
        n = (2*c)/g
        for x1 in range(1, int(n**0.5)+1):
            y1 = (n - x1**2)**0.5
            _y1 = y1 - int(y1)
            if _y1 == 0 and y1 > x1:
                x = g*x1**2
                y = g*y1**2
                a = int((x*y)**0.5)
                b = int(abs(x-y)/2)
                group.add((a, b))
    print(group)
    return len(group)

def get_factor(c):
    r = []
    x = 1
    while x <= c**0.5:
        if c % x == 0:
            r.append(x)
            if c//x != x:
                r.append(c//x)
        x += 1
    return r

if __name__=='__main__':
    z = input()
    nums = main(int(z))
    print(nums)

最大公因数

辗转相除法

又名欧几里得算法(Euclidean algorithm),目的是求出两个正整数的最大公约数。

两个正整数a和b(a>b),它们的最大公约数等于a除以b的余数c和b之间的最大公约数。比如10和25,25除以10商2余5,那么10和25的最大公约数,等同于10和5的最大公约数。

def gcd(a, b):
    m = max(a, b)
    n = min(a, b)
    r = m % n
    while r != 0:
        m = n
        n = r
        r = m % n
    return n

更相减损术

出自于中国古代的《九章算术》,也是一种求最大公约数的算法。

两个正整数a和b(a>b),它们的最大公约数等于a-b的差值c和较小数b的最大公约数。比如10和25,25减去10的差是15,那么10和25的最大公约数,等同于10和15的最大公约数。

def gcd(a, b):
    while a != b:
        if a > b:
            a -= b
        else:
            b -= a
    return a

所有因数

def get_factor(c):
    r = []
    x = 1
    while x <= c**0.5:
        if c % x == 0:
            r.append(x)
            if c//x != x:
                r.append(c//x)
        x += 1
    return r

参考文献

https://bbs.csdn.net/topics/616088159
密码学学习笔记 之 数论四大定理及应用

相关推荐
爱吃生蚝的于勒1 小时前
C语言内存函数
c语言·开发语言·数据结构·c++·学习·算法
ChoSeitaku6 小时前
链表循环及差集相关算法题|判断循环双链表是否对称|两循环单链表合并成循环链表|使双向循环链表有序|单循环链表改双向循环链表|两链表的差集(C)
c语言·算法·链表
Fuxiao___6 小时前
不使用递归的决策树生成算法
算法
我爱工作&工作love我6 小时前
1435:【例题3】曲线 一本通 代替三分
c++·算法
白-胖-子7 小时前
【蓝桥等考C++真题】蓝桥杯等级考试C++组第13级L13真题原题(含答案)-统计数字
开发语言·c++·算法·蓝桥杯·等考·13级
workflower7 小时前
数据结构练习题和答案
数据结构·算法·链表·线性回归
好睡凯7 小时前
c++写一个死锁并且自己解锁
开发语言·c++·算法
Sunyanhui17 小时前
力扣 二叉树的直径-543
算法·leetcode·职场和发展
一个不喜欢and不会代码的码农7 小时前
力扣105:从先序和中序序列构造二叉树
数据结构·算法·leetcode
前端郭德纲7 小时前
浏览器是加载ES6模块的?
javascript·算法