约数与倍数-第12届蓝桥杯选拔赛Python真题精选

[导读]:超平老师的Scratch蓝桥杯真题解读系列在推出之后,受到了广大老师和家长的好评,非常感谢各位的认可和厚爱。作为回馈,超平老师计划推出《Python蓝桥杯真题解析100讲》,这是解读系列的第45讲。

约数与倍数,本题是2020年11月21日举办的第12届蓝桥杯青少组Python编程选拔赛真题,题目要求编程计算并输出给定两个正整数的最大公约数和最小公倍数。

先来看看题目的要求吧。

一.题目说明

提示信息:

倍数与约数:如果a能被b整除,a就叫做b的倍数,b就叫做a的约数。约数和倍数都表示一个整数与另一个整数的关系,不能单独存在。

最大公约数:几个整数中公有的约数,叫做这几个数的公约数;其中最大的一个,叫做这几个数的最大公约数。

举例:12、16的公约数有1、2、4,其中最大的一个是4,所以4是12与16的最大公约数。

最小公倍数:几个自然数公有的倍数,叫做这几个数的公倍数,其中最小的一个,叫做这几个数的最小公倍数。

举例:4的倍数有4、8、12、16,….,6的倍数有6、12、18、24,….,4和6的公倍数有12、24,……其中最小的是12,所以4和6最小公倍数为 12。

编程实现:

分别输入两个正整数(1 < 正整数 < 201),输出这两个正整数的最大公约数M及最小公倍数N(注:M和N之间以一个英文逗号隔开)。

输入描述:

第1行输入第一个正整数

第2行输入第二个正整数

输出描述:

输出这两个正整数的最大公数M及最小公倍数N(M和N之间以一个英文逗号隔开)

样例输入:

4

6

样例输出:

2,12

二.思路分析

这是一道简单的数论题,考查的是最大公约数和最小公倍数算法,涉及的知识点包括循环、余数运算和函数。

最大公约数,也称最大公因数、最大公因子,指两个或多个整数共有约数中最大的一个,通常称之为GCD(Greatest Common Divisor)。

例如8和12,两个数的公约数分别为1、2、4,其中4为8和12的最大公约数。

图片

计算最大公约数的方法比较多,常见的有如下几种:

  • 枚举算法

  • 欧几里得算法

  • 更相减损术

  • Stein算法

其中最简单的就是枚举算法,其核心思想就是从较小的数字开始,寻找能同时被两个正整数整除的数字,直到1为止,一旦找到了,就结束循环。

欧几里得算法,又称辗转相除法,是一种高效的求解方法。它的基本思想是用两个数的余数进行迭代计算,直到余数为0时,此时的除数即为两个数的最大公约数。

该算法基于一个定理:

两个正整数a和b( a > b),它们的最大公约数等于a除以b的余数c和b之间的最大公约数。

我们先来看一看数字1112和695的最大公约数是多少吧,使用欧几里得算法的步骤如下:

图片

与最大公约数相对应的概念是最小公倍数,两个或多个整数公有的倍数叫做它们的公倍数,其中除0以外最小的一个公倍数就叫做最小公倍数,通常称之为LCM(Least Common Multiple)。

比如,要计算15和35的最小公倍数,如下所示:

图片

其计算方式也有多种,典型的有两种,第一种是使用枚举算法,第二种是利用最大公约数来计算。

我们可以利用这样一个事实:两个数的乘积等于它们的最大公约数和最小公倍数的乘积,也就是说:

a * b = GCD(a, b) * LCM(a, b)

因此,我们可以先计算最大公约数,然后用这个公式来获取最小公倍数。

思路有了,接下来,我们就进入具体的编程实现环节。

三.编程实现

根据上面的思路分析,我们使用两种方式实现:

  • 枚举算法

  • 欧几里得算法

1. 枚举算法

为了方便,我们可以定义函数来获取两个整数的最大公约数和最小公倍数,计算GCD的函数定义如下:

图片

代码不难,简单说明两点:

1). 需要比较a和b的大小,确保 a < b;

2). 注意从较小的a开始,直到1为止,一旦找到第一个公约数,它就是最大的,结束循环,返回即可。

计算LCM的函数定义如下:

图片

同样说明两点:

1). 仍然要比较a和b的大小,确保a < b;

2). 循环的次数无法确定,不能使用for...in循环,使用while更方便。

2. 欧几里得算法

接下来,我们使用欧几里得算法来计算最大公约数,定义函数如下:

图片

代码不多,强调一点,有些同学会先比较a和b的大小,这是可以的。但实际上不需要比较a和b的大小,因为算法本身会处理这种情况。无论a和b的初始大小关系如何,算法都会正确地计算出它们的最大公约数。

在每一次迭代中,我们将较小的数和较大的数除以较小数后的余数进行交换。由于余数总是小于除数,因此这个过程会确保我们总是用较小的数去除以较大的数,直到余数为0。

相应的,计算最小公倍数的函数定义如下:

图片

代码更为简单,注意使用的是整除运算符,确保得到的结果是整数。

有了前面定义的函数,接下来就简单了,代码如下:

图片

代码非常简单,说明两点:

1). 前面给出了两种算法,你只需要使用其中一种即可;

2). 最后输出的使用,需要使用逗号隔开,使用sep参数最简单,效果也最好。

至此,整个程序就全部完成了,你也可以输入不同的数字来测试效果了。

四.总结与思考

本题代码在10行左右,涉及到的知识点包括:

  • 输入输出;

  • 循环编程,包括for和while;

  • 余数运算;

  • 自定义函数;

本题难度一般,关键是要理解最大公约数和最小公倍数的含义,快速找到解决方案。

枚举算法是最简单的,也是我们解决大部分问题的首选,但是随着数字或者数据规模的增加,枚举算法的效率就会大大降低。

以上面的代码为例,假设我们有两个整数a和b(假设a <= b),使用枚举算法来计算它们的最大公约数的复杂度可以这样分析:

在最坏情况下,我们需要尝试从a(较小数)递减到1,检查每个数是否是a和b的公约数,因此,需要进行的比较次数是a次。

所以,枚举算法计算GCD的时间复杂度是O(a)。这个复杂度是线性的,意味着随着输入数a的增大,所需的时间也会线性地增长。

使用欧几里得算法时,我们是通过余数来不断减小数字的,其时间复杂度与a和b中较小者的值成对数关系,即O(log(min(a, b))),这在处理大整数时具有显著的优势。

超平老师给你留一道思考题,除了本文介绍的枚举算法和欧几里得算法,其它几种算法思想是怎样的,又该如何编写代码呢?

你还有什么好的想法和创意吗,也非常欢迎和超平老师分享探讨。

如果你觉得文章对你有帮助,别忘了点赞和转发,予人玫瑰,手有余香😄

需要源码的,可以移步至“超平的编程课”gzh。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/299212.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

非关系型数据库——Redis基本操作

目录 一、Redis数据库常用命令 1.Set——存放数据 2.Get——获取数据 3.Keys——获取符合条件的键值 4.Exists——判断键值是否存在 5.Del——删除指定键值 6.Type——获取键值对应的类型 7.Rename——对已有键值重命名&#xff08;覆盖&#xff09; 8.Renamenx——对…

更高效、更简洁的 SQL 语句编写丨DolphinDB 基于宏变量的元编程模式详解

元编程&#xff08;Metaprogramming&#xff09;指在程序运行时操作或者创建程序的一种编程技术&#xff0c;简而言之就是使用代码编写代码。通过元编程将原本静态的代码通过动态的脚本生成&#xff0c;使程序员可以创建更加灵活的代码以提升编程效率。 在 DolphinDB 中&#…

【智能算法】随机分形搜索算法(SFS)原理及实现

目录 1.背景2.算法原理2.1算法思想2.2算法过程 3.结果展示4.参考文献 1.背景 2015年&#xff0c;Salimi等人受到分形的扩散性质启发&#xff0c;提出了随机分形搜索算法&#xff08;Stochastic Fractal Search &#xff0c;SFS&#xff09;。 2.算法原理 2.1算法思想 SFS通…

《QT实用小工具·十一》Echart图表JS交互之仪表盘

1、概述 源码放在文章末尾 该项目为Echart图表JS交互之炫酷的仪表盘&#xff0c;可以用鼠标实时改变仪表盘的读数。 下面为demo演示&#xff1a; 该项目部分代码如下&#xff1a; #include "widget.h" #include "ui_widget.h" #include "qurl.h&q…

鸿蒙实战开发-如何使用Stage模型卡片

介绍 本示例展示了Stage模型卡片提供方的创建与使用。 用到了卡片扩展模块接口&#xff0c;ohos.app.form.FormExtensionAbility 。 卡片信息和状态等相关类型和枚举接口&#xff0c;ohos.app.form.formInfo 。 卡片提供方相关接口的能力接口&#xff0c;ohos.app.form.for…

[VulnHub靶机渗透] pWnOS 2.0

&#x1f36c; 博主介绍&#x1f468;‍&#x1f393; 博主介绍&#xff1a;大家好&#xff0c;我是 hacker-routing &#xff0c;很高兴认识大家~ ✨主攻领域&#xff1a;【渗透领域】【应急响应】 【Java、PHP】 【VulnHub靶场复现】【面试分析】 &#x1f389;点赞➕评论➕收…

Android 的网络加载

发起网络请求的过程 当用户在应用程序中输入网址或关键字时&#xff0c;应用程序会发起网络请求。这个过程大致如下&#xff1a; 应用程序将请求发送到服务器&#xff0c;服务器返回响应数据。应用程序接收到响应数据后&#xff0c;将其转换为应用程序可识别的数据格式。应用…

Mybatis--TypeHandler使用手册

TypeHandler使用手册 场景&#xff1a;想保存user时 teacher自动转String &#xff0c;不想每次保存都要手动去转String&#xff1b;从DB查询出来时&#xff0c;也要自动帮我们转换成Java对象 Teacher Data public class User {private Integer id;private String name;priva…

C++设计模式:策略模式(二)

1、定义与动机 定义一系列算法&#xff0c;把它们一个个封装起来&#xff0c;并且使它们可互相替换&#xff08;变化&#xff09;&#xff0c;该模式使得算法可独立于使用它的客户程序&#xff08;稳定&#xff09;而变化&#xff08;扩展&#xff0c;子类化&#xff09; 在软…

web安全学习笔记(6)

记一下第十节课的内容。 一.PHP语言中的if else判断 语法和c语言中非常类似&#xff0c;不再赘述&#xff0c;也可以使用if...elseif...elseif...else 1.True和False 2.&#xff0c;和 一个等号是赋值 两个等号是比较 三个等号是全等&#xff08;内容相等&#xff0c;数…

OpenHarmony开发-系统烧录

本文详细介绍了烧录OpenHarmony系统到开发板的操作流程。从基础的硬件准备和软件环境设置入手&#xff0c;详细说明了如何配置开发环境、构建系统镜像等过程&#xff0c;详细描述了烧录过程中的关键步骤&#xff0c;以及如何使用专用工具将OpenHarmony系统镜像传输到开发板。同…

第十四届蓝桥杯大赛软件赛省赛

第十四届蓝桥杯大赛软件赛省赛 2.日期统计 小蓝现在有一个长度为 100 的数组&#xff0c;数组中的每个元素的值都在 0 到 9 的范围之内。 数组中的元素从左至右如下所示&#xff1a; 5 6 8 6 9 1 6 1 2 4 9 1 9 8 2 3 6 4 7 7 5 9 5 0 3 8 7 5 8 1 5 8 6 1 8 3 0 3 7 9 2 7 …

PyQt6实战6--高亮

PyQt6实战3--sql查询器-CSDN博客 在sql查询器的基础上添加了sql语法的高亮 运行效果&#xff1a; 代码&#xff1a; 只需要在原来的代码上添加一行 rightTopLayout QVBoxLayout()rightTopLayout.addWidget(QLabel("输入sql:"))self.sql QTextEdit() #加一行高亮&…

【踩坑日记】因不同系统换行符不同导致的文本读取结果不同的问题

文章目录 1 问题现象描述2 解决过程&#xff08;点击直接跳到解决方法&#xff09;3 原因解释4 如何避免踩坑4.1 格式转换4.2 格式查看 1 问题现象描述 起因是群友问了这么一个问题 确实很奇怪&#xff0c;按理说第二个printf不会完全不输出&#xff0c;于是想到&#xff0c;…

多线程学习-线程池

目录 1.线程池的作用 2.线程池的实现 3.自定义创建线程池 1.线程池的作用 当我们使用Thread的实现类来创建线程并调用start运行线程时&#xff0c;这个线程只会使用一次并且执行的任务是固定的&#xff0c;等run方法中的代码执行完之后这个线程就会变成垃圾等待被回收掉。如…

7.二叉树的遍历方式及二叉树习题

4.二叉树链式结构的实现 二叉树是&#xff1a; 空树 非空&#xff1a;根节点&#xff0c;根节点的左子树、根节点的右子树组成的。 4.1二叉树的遍历 4.2.1 前序、中序以及后序遍历 前序遍历(Preorder Traversal 亦称先序遍历)——访问根结点的操作发生在遍历其左右子树之前…

161 Linux C++ 通讯架构实战15,线程池代码分析

线程池应该使用的地方 和 epoll 技术结合 线程池代码处理数据的地方。 线程池分析&#xff1a; 线程池代码1 threadpool_create //Tencent8888 start threadpool_create函数的目的初始化线程池&#xff0c;对应的struct是 threadpool_t /* 1.先malloc整个线程池的大小 2.这里…

Memcached 教程之 PHP 连接 Memcached 服务(十)

PHP 连接 Memcached 服务 在前面章节中我们已经介绍了如何安装 Memcached 服务&#xff0c;接下来我们为大家介绍 PHP 如何使用 Memcached 服务。 PHP Memcache 扩展安装 PHP Memcache 扩展包下载地址&#xff1a;PECL :: Package :: memcache&#xff0c;你可以下载最新稳定…

Vuex(vue 项目中实现 频繁、大范围数据共享的技术方案)

参考文档(点击查看) 好处 1.数据的存取一步到位&#xff0c;不需层层传递 2.数据的流动非常清晰 3.存储在Vuex中的数据都是响应式的&#xff08;数据更新后&#xff0c;使用数据的组件都会自动更新&#xff09; Vuex基础配置 npm i vuex3.6.2state中用来存储数据&#xff0c…

2_5.Linux存储的基本管理

实验环境&#xff1a; 系统里添加两块硬盘 ##1.设备识别## 设备接入系统后都是以文件的形式存在 设备文件名称&#xff1a; SATA/SAS/USB /dev/sda,/dev/sdb ##s SATA, dDISK a第几块 IDE /dev/hd0,/dev/hd1 ##h hard VIRTIO-BLOCK /de…