备战蓝桥杯Day32 - 欧几里得算法

求最大公约数

约数:如果整数a能被整数b整除,那么a叫做b的倍数,b叫做a的约数。

给定两个整数a,b,两个数的所有公共约数中的最大值即为最大公约数 (Greatest Common Divisor,GCD)。

它的基本思想是:对于整数a和b,利用辗转相除法,反复将a和b相除并取余数 ,直到余数为0为止。此时,非零的余数即为a和b的最大公约数。

该算法的原理可以用公式gcd(a,b) = gcd(b,a mod b)来表示,其中gcd表示最大公约数,mod表示取余操作。算法从a和b开始,反复进行取余操作,直到余数为0,此时的除数即为最大公约数。

代码实现

递归实现:

python 复制代码
def gcd(a, b):
    if b == 0:
        return a
    else:
        return gcd(b, a % b)

print(gcd(12,16))

非递归实现:

python 复制代码
def gcd(a, b):
    while b != 0:
        r = a % b
        a = b
        b = r
    return a

print(gcd(12,16))

分数计算

通过欧几里得算法,可以实现分数的约分和通分,从而实现分数的运算。

一个分数,分子分母上下同时约分的实现

python 复制代码
 def __init__(self, a, b):
        self.a = a
        self.b = b
        x = self.gcd(a, b)
        self.a /= x
        self.b /= x

求分母的最小公倍数方法:

python 复制代码
    def zgs(self, a,  b):
        x = self.gcd(a, b)
        return a * b / x

实现分数加法

python 复制代码
class Fraction:
    def __init__(self, a, b):  # 分子分母同时约分
        self.a = a
        self.b = b
        x = self.gcd(a, b)
        self.a /= x
        self.b /= x

    def gcd(self, a, b):  # 求最大公约数
        while b != 0:
            r = a % b
            a = b
            b = r
        return a

    def zgs(self,a,  b):  # 求最小公倍数
        x = self.gcd(a,b)
        return a*b/x

    def __add__(self, other):  # 加法实现
        a = self.a
        b = self.b
        c = other.a
        d = other.b
        fenmu = self.zgs(b, d)
        fenzi = a * fenmu / b + c * fenmu / d
        return Fraction(fenzi, fenmu)

    def __str__(self):  # 打印分数
        return "%d/%d" % (self.a, self.b)

# 测试案例
a = Fraction(1,3)
b = Fraction(1,2)
print(a+b)
相关推荐
代码小书生12 分钟前
math,一个基础的 Python 库!
人工智能·python·算法
AI科技星14 分钟前
全域数学·数术本源·高维代数卷(72分册)【乖乖数学】
人工智能·算法·数学建模·数据挖掘·量子计算
生成论实验室20 分钟前
《事件关系阴阳博弈动力学:识势应势之道》第一篇:生成正在发生——从《即事经》到事件-关系网络
人工智能·科技·算法·架构·创业创新
漂流瓶jz25 分钟前
UVA-1152 和为0的4个值 题解答案代码 算法竞赛入门经典第二版
数据结构·算法·二分查找·题解·aoapc·算法竞赛入门经典·uva
leoufung32 分钟前
LeetCode 76:Minimum Window Substring 题解与滑动窗口思维详解
算法·leetcode·职场和发展
小O的算法实验室1 小时前
2026年IEEE TETCI,山区环境下基于双种群进化的协同无人机巡逻任务协同优化,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
生成论实验室1 小时前
《事件关系阴阳博弈动力学:识势应势之道》第二篇:阴阳博弈——认知的动力学基础
数据结构·人工智能·科技·神经网络·算法
风筝在晴天搁浅2 小时前
字节高频题 小于n的最大数
算法
LabVIEW开发2 小时前
LabVIEW水力机组空蚀在线监测
算法·labview·labview知识·labview功能·labview程序
AI科技星2 小时前
科幻艺术书本封面:《全域数学》第一部·数术本源 第三卷 代数原本(P95-141)完整五级目录【乖乖数学】
算法·机器学习·数学建模·数据挖掘·量子计算