递归求最大公约数
#include <stdio.h>// 函数声明
int gcd(int a, int b);int main() {int x, y;printf("请输入两个正整数:");scanf("%d %d", &x, &y);printf("最大公约数是:%d\n", gcd(x, y));return 0;
}// 递归求最大公约数
int gcd(int a, int b) {return b == 0 ? a : gcd(b, a % b);
}
这种方法可以求最大公约数,因为它基于欧几里得算法(Euclidean algorithm),这是一种古老而高效的算法,用于计算两个整数的最大公约数(GCD)。欧几里得算法的核心思想是:两个整数的最大公约数与较小数和两数相除余数的最大公约数相同。
这里是欧几里得算法的基本原理:
1. 基本情况:如果其中一个数变为0,那么另一个数就是最大公约数。因为任何数和0的最大公约数都是它本身。
2. 递归步骤:对于任意两个正整数`a`和`b`(假设`a > b`),它们的最大公约数与`b`和`a % b`(`a`除以`b`的余数)的最大公约数相同。这是因为`a`可以表示为`a = bq + r`,其中`q`是商,`r`是余数。那么`a`和`b`的公约数也必定是`b`和`r`的公约数。
3. 重复应用:通过不断重复这个过程,直到其中一个数变为0,另一个数就是最大公约数。
这个算法之所以有效,是因为它利用了除法的性质和最大公约数的定义。每次递归调用实际上是在缩小问题的规模,直到达到基本情况。:
以一个具体的例子来说明:
假设我们要计算48和18的最大公约数
1. `48`和`18`的最大公约数与`18`和`48 % 18`(即`48`除以`18`的余数,也就是`12`)的最大公约数相同。
2. 然后我们计算`GCD(18, 12)`,这与`12`和`18 % 12`(即`6`)的最大公约数相同。
3. 接着计算`GCD(12, 6)`,这与`6`和`12 % 6`(即`0`)的最大公约数相同。
4. 由于其中一个数现在是`0`,算法终止,另一个数`6`就是`48`和`18`的最大公约数。
相关文章:
递归求最大公约数
#include <stdio.h>// 函数声明 int gcd(int a, int b);int main() {int x, y;printf("请输入两个正整数:");scanf("%d %d", &x, &y);printf("最大公约数是:%d\n", gcd(x, y));return 0; }// 递归求最大公约…...
关于在浏览器里面获取手机方向的事件
先说问题:浏览器有一个自带原生的获取手机方向的事件方法 deviceorientation: https://developer.mozilla.org/en-US/docs/Web/API/DeviceOrientationEvent/DeviceOrientationEvent 这个事件里面有个实例absolute 看名字知道意思吧,对就是绝对坐标的意…...
STM32 出租车计价器系统设计(一) 江科大源码改写
STM32 出租车计价器系统设计 功能目标 驱动步进电机模拟车轮旋转,并实现调速功能。 设置车轮周长和单价,检测车轮转速和运转时间。 计算并显示行驶里程和价格。 硬件材料 28BYJ48 五线四相步进电机和 ULN2003 驱动板模块 测速传感器模块 嵌入式小系统…...
eclipse rcp-创建rcp-创建target
1.创建一个target文件,将其命名为mine-rcp.target 2. 编辑target 2.1 点击add按钮,选中software site 2.2 选择一个software site 打开浏览器。 选择一个合适的eclipse作为基础版本。进入https://download.eclipse.org/eclipse/downloads/https://dow…...
微信小程序--创建一个日历组件
微信小程序–创建一个日历组件 可以创建一个日历组件,来展示当前月份的日期,并支持切换月份的功能。 一、目录结构 /pages/calendarcalendar.wxmlcalendar.scsscalendar.jscalendar.json二、calendar.wxml <view class"calendar"><…...
质量问题分析与改进常见方法
大同小异,本质都是定位、解决、推广三大步双归零 技术归零五条要求:“定位准确、机理清楚、问题复现、措施有效、举一反三”。 管理归零五条要求:“过程清楚、责任明确、措施落实、严肃处理、完善规章”。 航天FRACASFRACAS ,是“…...
质数的和与积
质数的和与积 C语言代码C 代码Java代码Python代码 💐The Begin💐点点关注,收藏不迷路💐 两个质数的和是S,它们的积最大是多少? 输入 一个不大于10000的正整数S,为两个质数的和。 输出 一个整…...
数据结构 (35)分配类排序
前言 分配类排序是数据结构中的一种重要排序方法,其核心思想是利用分配和收集过程对元素进行排序,而无需比较元素之间的关键字。这种方法突破了基于关键字比较的排序算法的时间下界,可以达到线性时间复杂度O(n)。 一、分配类排序的基本概念 分…...
Cesium隐藏默认控件
终于有时间开始整理下知识点了。 开搞 本地环境 vue3vitecesiumvite和cesium都是最新版本这里有个问题需要注意,就是如何为Cesium配置Vite,随便检索一下,大部分都时通过插件【vite-plugin-cesium】作为解决方案,我本地创建新的示…...
Spark SQL 执行计划解析源码分析
本文用于记录Spark SQL执行计划解析的源码分析。文中仅对关键要点进行提及,无法面面具到,仅描述大体的框架。 Spark的Client有很多种,spark-sql,pyspark,spark- submit,R等各种提交方式,这里以…...
rabbitMq举例
新来个技术总监,把 RabbitMQ 讲的那叫一个透彻,佩服! 生产者 代码举例 public String sendMsg(final String exchangeName,final String routingKey,final String msg) {} /*** 发送消息* param exchangeName exchangeName* param routin…...
奇怪的知识又增加了:ESP32下的Lisp编程=>ULisp--Lisp for microcontrollers
ESP32下有MicroPython,那么我就在想,有Lisp语言支持吗?答案是果然有!有ULisp,专门为MCU设计的Lisp! 网址:uLisp - Lisp for microcontrollers 介绍:用于微控制器的 Lisp 适用于 Ar…...
渗透测试之信息收集
免责声明:使用本教程或工具,用户必须遵守所有适用的法律和法规,并且用户应自行承担所有风险和责任。 文章目录 1. 基础信息收集2. 网络资产发现3. 网站和应用信息4. 技术栈识别5. 安全漏洞和配置6. 移动应用分析7.Google语法常见Google使用场…...
基本分页存储管理
一、实验目的 目的:熟悉并掌握基本分页存储管理的思想及其实现方法,熟悉并掌握基本分页存储管理的分配和回收方式。 任务:模拟实现基本分页存储管理方式下内存空间的分配和回收。 二、实验内容 1、实验内容 内存空间的初始化——可以由用户输…...
SQLServer到MySQL的数据高效迁移方案分享
SQL Server数据集成到MySQL的技术案例分享 在企业级数据管理中,跨平台的数据集成是一个常见且关键的任务。本次我们将探讨如何通过轻易云数据集成平台,将巨益OMS系统中的退款单明细表从SQL Server高效、安全地迁移到MySQL数据库中。具体方案名称为“7--…...
软考:工作后再考的性价比分析
引言 在当今的就业市场中,软考(软件设计师、系统分析师等资格考试)是否值得在校学生花费时间和精力去准备?本文将从多个角度深入分析软考在不同阶段的性价比,帮助大家做出明智的选择。 一、软考的价值与局限性 1.1 …...
shell编程(完结)
shell编程(完结) 声明! 学习视频来自B站up主 泷羽sec 有兴趣的师傅可以关注一下,如涉及侵权马上删除文章 笔记只是方便各位师傅的学习和探讨,文章所提到的网站以及内容,只做学习交流,其…...
UNIX数据恢复—UNIX系统常见故障问题和数据恢复方案
UNIX系统常见故障表现: 1、存储结构出错; 2、数据删除; 3、文件系统格式化; 4、其他原因数据丢失。 UNIX系统常见故障解决方案: 1、检测UNIX系统故障涉及的设备是否存在硬件故障,如果存在硬件故障…...
adb连接逍遥安卓模拟器失败的问题解决方案
1、逍遥安卓模拟器进入系统应用,设置-关于平板电脑-版本号,连续点击3次以上,直到提示进入开发者模式,返回设置界面,进入【开发者选项】-【USB调试】开启,之后重启模拟器再次adb尝试连接。 2、android stud…...
【昇腾】NPU ID:物理ID、逻辑ID、芯片映射关系
起因: https://www.hiascend.com/document/detail/zh/Atlas%20200I%20A2/23.0.0/re/npu/npusmi_013.html npu-smi info -l查询所有NPU设备: [naienotebook-npu-bd130045-55bbffd786-lr6t8 DCNN]$ npu-smi info -lTotal Count : 1NPU…...
别再让POI吃掉你的内存了!用SAX模式轻松处理10万行Excel数据(附完整Java代码)
高效解析海量Excel数据的Java实践指南 在处理企业级数据时,Excel文件往往是不可避免的数据交换格式。但当数据量达到数万行甚至更多时,传统的POI用户模式会迅速耗尽JVM内存,导致系统崩溃。本文将深入探讨如何利用SAX事件驱动模型解决这一痛点…...
VisualHMI Lua定时器深度解析:从核心机制到工业级倒计时实战
1. 项目概述与核心价值在工业HMI(人机界面)和串口屏的开发中,定时器是一个基础但至关重要的功能模块。无论是实现一个简单的延时开关、一个周期性的数据采集任务,还是一个复杂的倒计时控制逻辑,都离不开对定时器的精准…...
使用TaotokenCLI工具一键配置团队统一的模型调用环境
🚀 告别海外账号与网络限制!稳定直连全球优质大模型,限时半价接入中。 👉 点击领取海量免费额度 使用TaotokenCLI工具一键配置团队统一的模型调用环境 在团队协作开发中,确保每位成员使用统一的大模型接入配置&#x…...
Audiveris终极指南:10分钟快速掌握开源乐谱识别技术
Audiveris终极指南:10分钟快速掌握开源乐谱识别技术 【免费下载链接】audiveris Latest generation of Audiveris OMR engine 项目地址: https://gitcode.com/gh_mirrors/au/audiveris 还在为纸质乐谱难以数字化而烦恼吗?Audiveris作为一款功能强…...
ELAU 艾乐 BCH16HD02330A5C 伺服电机:小型自动化设备的精准动力解决方案
一、产品概述ELAU 艾乐作为施耐德电气旗下专注于运动控制领域的高端品牌,凭借其在工业自动化领域数十年的技术积累,推出了 BCH 系列高性能伺服电机。其中,BCH16HD02330A5C作为该系列中针对小型设备优化的型号,以 "小体积、高…...
如何快速解密QQ音乐加密文件:QMCDecode的完整使用指南
如何快速解密QQ音乐加密文件:QMCDecode的完整使用指南 【免费下载链接】QMCDecode QQ音乐QMC格式转换为普通格式(qmcflac转flac,qmc0,qmc3转mp3, mflac,mflac0等转flac),仅支持macOS,可自动识别到QQ音乐下载目录,默认转…...
Gemini CLI扩展生态:AI如何重塑命令行开发与运维工作流
1. 从命令行到智能副驾:Gemini CLI 扩展生态深度解析如果你和我一样,是个常年泡在终端里的开发者或运维,那么“效率”这个词几乎刻在了骨子里。我们习惯于用脚本自动化一切,用管道连接工具,用命令行精准地操控系统。但…...
叛逆期不是“麻烦期”:是孩子建立自我的关键期
很多父母一听到“叛逆期”三个字就头疼,觉得孩子开始不听话、顶嘴、唱反调,家里从此不得安宁。但换个角度来看,所谓的叛逆,其实是孩子成长中一个非常重要的信号。它不是在故意跟父母作对,而是在告诉大人:我…...
免费获取Axure中文界面:5分钟解决原型设计语言障碍
免费获取Axure中文界面:5分钟解决原型设计语言障碍 【免费下载链接】axure-cn Chinese language file for Axure RP. Axure RP 简体中文语言包。支持 Axure 11、10、9。不定期更新。 项目地址: https://gitcode.com/gh_mirrors/ax/axure-cn 还在为Axure RP的…...
【c++面向对象编程】第18篇:多继承与菱形继承(一):二义性问题与虚拟继承
目录 一、多继承的基本语法 二、二义性问题:两个基类有同名成员 解决方案1:用作用域运算符明确指定 解决方案2:在派生类中重写(覆盖) 三、菱形继承(钻石问题) 菱形继承带来的两个问题 查看…...
