059、Python 函数练习:用函数实现求两个数的最大公约数和最小公倍数

本文主要是介绍059、Python 函数练习:用函数实现求两个数的最大公约数和最小公倍数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

普及:写程序有两个终极原则:高内聚,低耦合。

所谓高内聚指的是一个模块或类内部各个元素(方法、属性等)彼此关联紧密,共同完成一个特定的任务或目标。具有高内聚的模块或类内的元素之间联系紧密,功能相关联,实现单一功能的代码集中在一起。

所谓低耦合指的是模块或类之间的依赖关系尽可能地降低,模块之间通过接口进行通信,各模块之间独立性强,一个模块的改动不会对其他模块造成较大影响。低耦合的设计使得系统更容易扩展、维护和测试。

言归正传,要用函数实现求两个数的最大公约数和最小公倍数跟上面提到的又有什么关系呢。

这里就涉及一个设计函数的重要原则:单一职责原则(一个函数只做好一件事情),这一原则就是秉承了上面提到的高内聚

所以要遵循上面的原则,那么我们要实现求两个数的最大公约数和最小公倍数,最优做法就是分开两个函数来分别实现最大公约数和最小公倍数。

具体如何实现?

1、定义:

最大公约数:指两个或多个整数共有约数中最大的一个。换句话说,最大公约数是能够同时整除给定整数的最大正整数。

最小公倍数:两个整数a和b的最小公倍数是能同时整除a和b的最小正整数。

2、思路:

求最大公约数的思路:使用欧几里德算法:两个整数的最大公约数等于其中较小的数和两数相除余数的最大公约数。通过反复用较小数和余数进行相除直到余数为0,最后的除数即为最大公约数。

求最小公倍数的思路:两个整数a和b的最小公倍数等于这两个数的乘积除以它们的最大公约数。

3、代码实现:

"""
example059 - 用函数实现求两个数的最大公约数和最小公倍数Author: 不在同一频道上的呆子
Date: 2024/6/16
"""# 求两个数的最大公约数
def gcd(a, b):while b:a, b = b, a % breturn a# 求两个数的最小公倍数
def lcm(a, b):return a * b // gcd(a, b)# 输入两个整数
num1 = 24
num2 = 36# 求最大公约数
result_gcd = gcd(num1, num2)
print(f"最大公约数({num1}, {num2}) = {result_gcd}")# 求最小公倍数
result_lcm = lcm(num1, num2)
print(f"最小公倍数({num1}, {num2}) = {result_lcm}")

这篇关于059、Python 函数练习:用函数实现求两个数的最大公约数和最小公倍数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1071708

相关文章

SpringBoot集成Milvus实现数据增删改查功能

《SpringBoot集成Milvus实现数据增删改查功能》milvus支持的语言比较多,支持python,Java,Go,node等开发语言,本文主要介绍如何使用Java语言,采用springboo... 目录1、Milvus基本概念2、添加maven依赖3、配置yml文件4、创建MilvusClient

python logging模块详解及其日志定时清理方式

《pythonlogging模块详解及其日志定时清理方式》:本文主要介绍pythonlogging模块详解及其日志定时清理方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录python logging模块及日志定时清理1.创建logger对象2.logging.basicCo

JS+HTML实现在线图片水印添加工具

《JS+HTML实现在线图片水印添加工具》在社交媒体和内容创作日益频繁的今天,如何保护原创内容、展示品牌身份成了一个不得不面对的问题,本文将实现一个完全基于HTML+CSS构建的现代化图片水印在线工具... 目录概述功能亮点使用方法技术解析延伸思考运行效果项目源码下载总结概述在社交媒体和内容创作日益频繁的

Python如何自动生成环境依赖包requirements

《Python如何自动生成环境依赖包requirements》:本文主要介绍Python如何自动生成环境依赖包requirements问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑... 目录生成当前 python 环境 安装的所有依赖包1、命令2、常见问题只生成当前 项目 的所有依赖包1、

如何将Python彻底卸载的三种方法

《如何将Python彻底卸载的三种方法》通常我们在一些软件的使用上有碰壁,第一反应就是卸载重装,所以有小伙伴就问我Python怎么卸载才能彻底卸载干净,今天这篇文章,小编就来教大家如何彻底卸载Pyth... 目录软件卸载①方法:②方法:③方法:清理相关文件夹软件卸载①方法:首先,在安装python时,下

python uv包管理小结

《pythonuv包管理小结》uv是一个高性能的Python包管理工具,它不仅能够高效地处理包管理和依赖解析,还提供了对Python版本管理的支持,本文主要介绍了pythonuv包管理小结,具有一... 目录安装 uv使用 uv 管理 python 版本安装指定版本的 Python查看已安装的 Python

shell编程之函数与数组的使用详解

《shell编程之函数与数组的使用详解》:本文主要介绍shell编程之函数与数组的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录shell函数函数的用法俩个数求和系统资源监控并报警函数函数变量的作用范围函数的参数递归函数shell数组获取数组的长度读取某下的

使用Python开发一个带EPUB转换功能的Markdown编辑器

《使用Python开发一个带EPUB转换功能的Markdown编辑器》Markdown因其简单易用和强大的格式支持,成为了写作者、开发者及内容创作者的首选格式,本文将通过Python开发一个Markd... 目录应用概览代码结构与核心组件1. 初始化与布局 (__init__)2. 工具栏 (setup_t

Python中局部变量和全局变量举例详解

《Python中局部变量和全局变量举例详解》:本文主要介绍如何通过一个简单的Python代码示例来解释命名空间和作用域的概念,它详细说明了内置名称、全局名称、局部名称以及它们之间的查找顺序,文中通... 目录引入例子拆解源码运行结果如下图代码解析 python3命名空间和作用域命名空间命名空间查找顺序命名空

Python如何将大TXT文件分割成4KB小文件

《Python如何将大TXT文件分割成4KB小文件》处理大文本文件是程序员经常遇到的挑战,特别是当我们需要把一个几百MB甚至几个GB的TXT文件分割成小块时,下面我们来聊聊如何用Python自动完成这... 目录为什么需要分割TXT文件基础版:按行分割进阶版:精确控制文件大小完美解决方案:支持UTF-8编码