用python实现求两个整数的最大公约数
def gcd(a, b): """计算最大公约数""" while b: a, b = b, a % b return abs(a)
下面是对 gcd 函数的逐行解释:
def gcd(a, b):"""计算最大公约数"""
- 定义函数:这里定义了一个名为
gcd的函数,它接受两个参数a和b,并返回它们的最大公约数(GCD)。函数文档字符串用来描述它的功能。
while b:
- 循环条件:这行代码是一个
while循环,它会持续执行,直到b为 0。根据辗转相除法的原理,只要b不为 0,就可以继续计算最大公约数。
a, b = b, a % b
- 更新值:在循环中,通过同时赋值来更新
a和b的值:a被赋值为当前的b。b被赋值为a对b的模(余数)a % b。
- 这个过程利用了辗转相除法的核心思想:最大公约数(gcd(a, b))等于最大公约数(gcd(b, a % b))。
return abs(a)
- 返回结果:当循环结束时,
b会变为 0,此时a就是a和b的最大公约数。函数返回abs(a),即a的绝对值。这是因为最大公约数的定义通常是非负的。
总结
这个 gcd 函数实现了求两个整数的最大公约数。通过反复取余的方式逐步逼近这个值,直到其中一个数为零。最终返回的就是它们的最大公约数。这一算法的效率很高,时间复杂度为 O(log(min(a, b)))。
我们来计算 8 和 6 的最大公约数(GCD),使用前面提到的 gcd 函数。
示例:计算 8 和 6 的最大公约数
-
初始化:将
a = 8,b = 6。 -
第一次迭代:
while b:这里b是 6,继续执行。- 计算
a % b,即8 % 6 = 2。 - 更新值:
a = 6,b = 2。
-
第二次迭代:
while b:这里b是 2,继续执行。- 计算
a % b,即6 % 2 = 0。 - 更新值:
a = 2,b = 0。
-
结束循环:
- 由于
b现在为 0,循环结束。 - 返回
abs(a),即abs(2),结果是 2。
- 由于
结论
因此,8 和 6 的最大公约数是 2。
总结步骤
与之前的示例相同,我们通过不断取模的方法逐步缩小问题的规模。最终,我们得到了这两个数的最大公约数,即 2。
计算 6 和 8 的最大公约数(GCD)与计算 8 和 6 的过程非常相似,因为最大公约数的顺序并不影响结果。我们来详细看一下步骤:
示例:计算 6 和 8 的最大公约数
-
初始化:将
a = 6,b = 8。 -
第一次迭代:
while b:这里b是 8,继续执行。- 计算
a % b,即6 % 8 = 6(因为 6 小于 8,结果是 6)。 - 更新值:
a = 8,b = 6。
-
第二次迭代:
while b:这里b是 6,继续执行。- 计算
a % b,即8 % 6 = 2。 - 更新值:
a = 6,b = 2。
-
第三次迭代:
while b:这里b是 2,继续执行。- 计算
a % b,即6 % 2 = 0。 - 更新值:
a = 2,b = 0。
-
结束循环:
- 由于
b现在为 0,循环结束。 - 返回
abs(a),即abs(2),结果是 2。
- 由于
结论
因此,6 和 8 的最大公约数也是 2。
总结
无论是计算 6 和 8,还是 8 和 6,得到的结果都是相同的,最大公约数是 2。这表明计算的顺序不影响最终结果。
相关文章:
用python实现求两个整数的最大公约数
def gcd(a, b): """计算最大公约数""" while b: a, b b, a % b return abs(a) 下面是对 gcd 函数的逐行解释: def gcd(a, b):"""计算最大公约数"""定义函数:这里定义了一个名为 gcd…...
Linux 内核源码分析---proc 文件系统
proc文件系统 进程数据文件系统(process data filesystem, procfs)装载在 /proc,缩写为 procFS。 proc 文件系统是一种虚拟文件系统,其信息不能从块设备读取。只有在读取文件内容时才动态生成相应的信息。使用proc文件系统&…...
视频号直播回放怎么下载?
一、如果是下载自己直播回放视频: 方法一:视频号助手 打开网址:视频号助手 登陆账号后。下面路径,先点击成回放, 后就可以在下面路径,下载全场回放 但是这种有个缺点,就是不能分段下载。这样…...
【第九节】python中xml解析和json编解码
目录 一、Python XML 解析 1.1 什么是XML 1.2 Python 对 XML 的解析方法 1.3 SAX解析xml 1.4 xml.dom解析xml 1.6 ElementTree解析XML 二、Python编解码json 2.1 什么是json 2.2 使用json 库 2.3 使用第三方库Demjson 一、Python XML 解析 1.1 什么是XML XML&#x…...
yolo v8部署到云服务器问题记录
环境安装 1、运行项目报错:no python application found, check your startup logs for errors 在云服务器pytorch版本安装错了,安装了GPU版本,需要安装CPU版本 # CPU only 使用下面这段代码避免出现第二个错误 pip install torch2.3.1 to…...
端口被占用,杀死进程的步骤
一、 查看所有进程占用的端口 在开始-运行-cmd,输入:netstat –ano可以查看所有进程 二、查看占用指定端口的程序 查看被那个端口占用,可以用该命令: 三、使用命令杀死进程 杀死进程,使用命令:...
接口入门(企业常见使用,一分钟搞定版)
目录 1、接口的定义 定义位置 接口内容 2、接口的使用 正常实现接口 接口当做函数参数 匿名实现接口 3、OPPO便签接口具体分析 总结一下: 1、接口的定义 定义位置 可以写在类中,但注意现在接口名字是 类名.接口名 可以单独写在一个文件 接口内…...
深入解析:Cookie 与 Session 的区别及应用场景
引言 在Web开发中,Cookie 和 Session 是两种常用的用户状态管理机制。虽然它们的目标都是在无状态的HTTP协议中维护用户的状态,但它们的工作原理和适用场景却有所不同。在本文中,我们将深入探讨 Cookie 和 Session 的区别,并通过…...
LLM金融文本分类文档说明
Python注意事项: 1,创建虚拟环境: conda create --prefixD:\software\Anaconda3\envs\finance_analysis python3.10.4 conda create -p D:/software/anaconda3/envs/finance_analysis python3.10.4 注释: D:\software\anaconda3\e…...
EI检索,2天录用,3天见刊!截稿在即,这本水刊你还不投吗?
点击关注:关注GZH【欧亚科睿学术】,GET完整版2023JCR分区列表! 🎉 🎉 🎉 🎉 恭喜!这本毕业水刊仅2天录用!3天见刊! 重要时间节点如下 2024-08-03 Sub…...
sql获取过去的小时数
TIMESTAMPDIFF(HOUR, create_time, NOW()) AS pastHours 是一条 SQL 语句的一部分,它使用 TIMESTAMPDIFF 函数来计算两个时间点之间的差异,并将结果标记为 pastHours。 让我们详细解析一下这条语句: TIMESTAMPDIFF 函数: 这个函数用于计算两…...
【Android Studio】彻底卸载
文章目录 卸载程序控制面板卸载安全软件卸载 重启计算机删除文件重启计算机 我们在Android开发时涉及重装时,如果卸载不干净,再次安装是不会正常运行项目的,接下来就让我教你如何删除干净吧。 卸载程序 控制面板卸载 control控制面板一>…...
美术版权可以当做商标使用吗
美术版权与商标的区别及不可混用性分析 在知识产权领域,美术版权和商标权是两个重要的概念,它们各自承载着不同的法律意义和保护范围。 美术版权概述 美术版权,又称著作权,是指著作权人对其创作的美术作品所享有的权利。这些作品…...
控制某些请求不记录日志
说明:由于统一拦截日志请求,导致所有匹配的请求都会打印日志,这里需要控制有些请求执行不打印日志,比如定时每隔几秒执行某些请求。 具体实现如下: 一、自定义注解,如下: /** * Description: …...
Java线程池原理剖析和应用指南
目录 Java线程池详解一、Java线程池简介池化思想池化思想的优点 二、线程池的实现原理分析实现线程池需要考虑哪些问题?线程池的简单使用示例线程池原理的简单图示 三、Executor详解Executor简介Executor框架的继承结构总结ExecutorExecutorService 四、ThreadPoolE…...
ST-LINK烧录MCU
打开ST-LINK软件: 主板断电状态下接入烧录器,烧录器USB连接电脑: 主板上电,点击连接按钮: 点击加载文件: 点击写入按钮,烧录成功后拔掉烧录器,主板重新上电...
Go - 10. * 值类型和指针类型的差异
目录 一.引言 二.接收者类型 三.代码示例 1.指针接收者 2.值接收者 3.运行结果对比 4.代码修改 5.刨根问底 四.总结 一.引言 go 语言中 func (c *Title) 和 func (c Title) 两个方法的传参差一个 * 号,二者的区别是一个是指针类型,一个是值类型…...
waf绕过:网络安全狗绕过
引言: 所有的绕过原理都大致一致,但是并不是所有的绕过都能起到作用,渗透测试主要还是一个猜加试的过程,本文仅供参考 网络攻击或扫描绕过 1.get绕过(未开启cc防护) 网络安全狗的默认防护为,拒…...
Django中的模型小总结:
from django.db import models from django.urls import reverse# 自定义Manager方法 class HighRatingManager(models.Manager):def get_queryset(self):return super().get_queryset().filter(rating1)# CHOICES选项 class Rating(models.IntegerChoices):VERYGOOD 1, Very …...
深入理解 RDMA 的软硬件交互机制
作者:羽京 一、前言 随着数据中心的飞速发展,高性能网络不断挑战着带宽与时延的极限,网卡带宽从过去的 10 Gb/s 、25 Gb/s 到如今的 100 Gb/s、200 Gb/s 再到下一代的 400Gb/s 网卡,其发展速度已经远大于 CPU 发展的速度。 为了…...
2026 企业办公家具采购指南:如何成为高端定制首选?
企业办公环境不仅是工作场所,更是公司的“第一面片”。对于行政采购人员而言,如何在预算范围内选择既有质感又靠谱的厂家?本文以佛山知名定制厂家——佛山市豪亿家具(Hooye) 为例,为您梳理采购避坑指南。一…...
五、QEMU+MIPS环境搭建实战:从零构建跨架构调试环境
1. 为什么需要QEMUMIPS环境? 在嵌入式设备逆向分析领域,MIPS架构的路由器固件分析是个常见需求。但真实路由器硬件往往缺乏调试接口,直接动态调试就像在黑箱里摸象。这时候QEMU就像个万能翻译官,能在x86电脑上完美复现MIPS程序的运…...
CosyVoice2-0.5B入门教程:3步搭建你的专属AI语音克隆系统
CosyVoice2-0.5B入门教程:3步搭建你的专属AI语音克隆系统 1. 快速了解CosyVoice2-0.5B CosyVoice2-0.5B是阿里开源的一款强大的语音克隆与合成系统,它能让你用短短几秒钟的语音样本,克隆出几乎一模一样的声音。想象一下,你可以让…...
高效卸载Microsoft Edge:解决浏览器残留问题的PowerShell工具
高效卸载Microsoft Edge:解决浏览器残留问题的PowerShell工具 【免费下载链接】EdgeRemover A PowerShell script that correctly uninstalls or reinstalls Microsoft Edge on Windows 10 & 11. 项目地址: https://gitcode.com/gh_mirrors/ed/EdgeRemover …...
模数OPC社区在北京亦庄正式启航
打造AI创业“超级孵化器”,首批迎来20个创业团队入驻4月8日,在北京经济技术开发区(简称“北京经开区”,又称“北京亦庄”)举办的AI FUTURE北京亦庄AI未来大会上,一个全新的AI创业孵化空间——模数OPC&#…...
Linux操作系统-系统安装与三种网络模式
本文将指导您在VMware Workstation 16 Pro环境下安装CentOS 7系统,详细介绍从创建虚拟机到完成操作系统安装的完整步骤。一、创建虚拟机1.点击“文件”菜单,选择“创建虚拟机”,然后点击“自定义”开始创建虚拟机。2.点击"浏览"按钮…...
WuliArt Qwen-Image Turbo惊艳效果:1024×1024输出中火焰/水流/烟雾动态形态自然度
WuliArt Qwen-Image Turbo惊艳效果:10241024输出中火焰/水流/烟雾动态形态自然度 你有没有想过,用AI生成一张火焰燃烧、水流奔腾或者烟雾缭绕的图片,结果却得到一团僵硬、模糊、毫无生气的色块?这几乎是所有文生图模型在处理动态…...
小白也能玩转AI配音!Fish Speech 1.5一键部署实战指南
小白也能玩转AI配音!Fish Speech 1.5一键部署实战指南 想让你的文字变成专业级语音吗?Fish Speech 1.5作为一款强大的AI语音合成工具,支持12种语言和声音克隆功能,现在通过CSDN星图镜像,只需简单几步就能快速体验。本…...
ThinkPHP5防跨目录访问报错?手把手教你如何安全解除LNMP的open_basedir限制
ThinkPHP5跨目录访问难题:LNMP环境下open_basedir限制的深度解析与安全实践 当你在LNMP环境中部署ThinkPHP5应用时,是否遇到过这样的报错信息?那些红色的"Warning"和"Fatal error"不仅打断了安装流程,更让人对…...
DeepSeek-OCR-2部署教程:如何在多卡服务器上分配显存并行处理批量文档
DeepSeek-OCR-2部署教程:如何在多卡服务器上分配显存并行处理批量文档 1. 项目概述 DeepSeek-OCR-2是一个基于多模态视觉大模型的智能文档解析系统,能够将图像中的文档内容转换为结构化的Markdown格式。与传统OCR技术相比,它不仅能够识别文…...
