左手Python 右手R —— 最大公约数和最小公倍数

news2024/11/23 15:53:30

左手Python 右手R —— 最大公约数和最小公倍数

  • 前言
  • 1、 最大公约数
    • 1.1 约数
    • 1.2 最大公约数
    • 1.3 求解方法
  • 2、 最小公倍数
    • 2.1 倍数
    • 2.2 最小公倍数
    • 2.3 求解方法
  • 3、程序实现
    • 3.1 python 代码实现
    • 3.2 R语言代码实现
  • 小结
    • 创作不易,都浏览到这儿了,看官可否将下面的收藏点赞帮忙点亮。


前言

  此专栏为python与R语言对比学习的文章;以通俗易懂的小实验,带领大家深入浅出的理解两种语言的基本语法,并用以实际场景!感谢大家的关注,希望对大家有所帮助。
  “博观而约取,厚积而薄发!”谨以此言,望诸君共勉

  本文针对数学问题“最大公约数、最小公倍数”进行讲解。具体的项目介绍见下文。


1、 最大公约数

1.1 约数

  在讲述最大公约数之前我们先来认识一下什么是约数。约数(又称因数),整数a除以整数b(b≠0) 除得的商正好是整数而没有余数,我们就说a能被b整除,或b能整除a。a称为b的倍数,b称为a的约数。因此不能孤立地说某个整数是约数。
  如: 4 = 1 ∗ 4 = 2 ∗ 2 【则称 4 、 2 、 1 是 4 的约数】 4=1*4=2*2 【则称4、2、1是4的约数】 4=14=22【则称4214的约数】
     6 = 1 ∗ 6 = 2 ∗ 3 【则称 6 、 3 、 2 、 1 是 6 的约数】 6=1*6=2*3 【则称6、3、2、1是6的约数】 6=16=23【则称63216的约数】
     . . . . . . . . . . . . . . . . . . .................. ..................
    注:一个数的约数必然包括1及其本身。

1.2 最大公约数

  如上展示的例子中,如果一个数c既是数a的约数,又是数b的约数,那么c叫做a与b的公约数。两个数的公因数中最大的一个,叫做这两个数的最大公约数。
  如: 在上面的例子中, 4 和 6 的公约数有: 1 、 2 。 在上面的例子中,4和6的公约数有:1、2。 在上面的例子中,46的公约数有:12
                4 和 6 的最大公约数是 2 。 4和6的最大公约数是2。 46的最大公约数是2

1.3 求解方法

  在知道约数及最大公约数的基本概念之后,我们进行求解,找出任意两个数的最大公约数:(此处展示常用的两种解法)
例: 求解 12 和 18 的最大公约数。

  枚举法: 12 的约数有 12 、 6 、 4 、 3 、 2 、 1 12的约数有 12、6、4、3、2、1 12的约数有1264321
       18 的约数有 18 、 9 、 6 、 3 、 2 、 1 18的约数有 18、9、6、3、2、1 18的约数有1896321
       所以 18 和 12 的最大约数是 6 所以18和12的最大约数是6 所以1812的最大约数是6

  短除法: 短除符号就像一个倒过来的除号,短除法就是先写出要求最大公因数的两个数A、B,再画一个短除号,接着在原本写除数的位置写两个数公有的质因数Z(通常从最小的质数开始),然后在短除号的下方写出这两个数被Z整除的商a,b,对a,b重复以上步骤,以此类推,直到最后的商互质为止,再把所有的除数相乘,其积即为A,B的最大公因数。
在这里插入图片描述
  程序求解: 采取短除法的逆向思维,短除法从最小的公质数开始,此法能快速找到除了1的最小公约数,反其道而行,如若我们重较小数开始递减,满足能同时被 x y 整除;则该数就是最大公约数。
在这里插入图片描述


2、 最小公倍数

2.1 倍数

  一个整数能够被另一个整数整除,那么这个整数就是另一整数的倍数。与约数不同的是,一个数可以有无数个倍数,而约数是有限的,因此无法通过枚举法完全展示出一个数的倍数。
  如: 15 / 5 = 3 【则称 15 是 5 的 3 倍、或 15 是 3 的 5 倍】 15 / 5 = 3 【则称15是5的3倍、或15是3的5倍】 15/5=3【则称1553倍、或1535倍】

2.2 最小公倍数

  两个或多个整数公有的倍数叫做它们的公倍数。倍数可以有无数多个,也可以无限大,因此多个整数之间只有最小公倍数。
  如: 12 的倍数有 0 、 12 、 24 、 36 、 48 、 60 、 72...... 12的倍数有 0、12、24、36、48、60、72...... 12的倍数有0122436486072......
     18 的倍数有 0 、 18 、 36 、 54 、 72 、 90 、 108...... 18的倍数有 0、18、36、54、72、90、108...... 18的倍数有01836547290108......
     则称 12 和 18 的最小公倍数为 36 则称 12 和18的最小公倍数为36 则称1218的最小公倍数为36

2.3 求解方法

  在知道倍数及最小公倍数的基本概念之后,我们进行求解,找出任意两个数的最小公倍数:(此处展示常用的两种解法)任然是求12和18的最小公倍数。
  短除法: 与上面一样的算法,只是在最后的结果时把所有的除数和余数相乘。
在这里插入图片描述
  公式法: 所谓公式法(最大公约数与最小公倍数关系)就是对于任意两个自然数 a 、 b a、b ab,只要先求出这两个数的最大公约数后,利用公式 [ a , b ] ∗ ( a , b ) = a ∗ b [a,b] *(a,b) =a*b [ab](ab)=ab即可求出最小公倍数 [ a , b ] = a ∗ b / ( a , b ) [a,b]=a*b/(a,b) [ab]=ab/(ab) ,也即是两个数的最小公倍数等于这两个数的乘积除以这两个数的最大公约数。这里可以取两个质数进行验证
3 和 5 的最大公约数为 1 则有最小公倍数 = 3 ∗ 5 / 1 = 15 3和5的最大公约数为1 则有最小公倍数=3*5/1=15 35的最大公约数为1则有最小公倍数=35/1=15


3、程序实现

程序仅展示公式法求最小公倍数

3.1 python 代码实现

x = int(input('x = '))
y = int(input('y = '))

# 如果 x 大于 y 就交换 x y 的值
if x > y:
    trmp = y
    y = x
    x = temp

# 从两个数中较小的数开始做递减循环
for fac in range(x,0,-1):
    if x % fac == 0 and y % fac == 0 :
        print('{}和{}的最大公约数是:{}'.format(x,y,fac))
        print('{}和{}的最小公倍数是:{}'.format(x,y,x*y//fac))
        break

在这里插入图片描述

3.2 R语言代码实现

math_diy <- function(){
  
  x <- as.integer(readline("X = "))
  y <- as.integer(readline("y = "))
  
  if(x > y){
    temp <- x
    x <- y
    y <- temp
  }
  
  for (i in x:-1) {
    if((x %% i== 0 & y %% i == 0)){
      cat("最大公约数为:",i)
      cat("\n最小公倍数为:",x*y%/%i)
      break
    }
  }
}
test_5 <- function(){
  print("请输入需要计算的数值")
  math_diy()
}
test_5()

在这里插入图片描述

小结

  本次仍然是对条件、循环、及自定函数的混合使用;
  R语言看起来比较复杂,无非是都嵌套在了自定函数里,如有问题,可以私信哦!
  任何问题只要了解了本质,都能通过代码实现;大家可以自己练习一下。

  这是左手Python右手R系列的第3片文章,希望大家能喜欢这个系列。

创作不易,都浏览到这儿了,看官可否将下面的收藏点赞帮忙点亮。

在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【Linux系统创建,修改用户和组和修改目录文件的权限以及实验的心得体会】

实验过程 1.创建一个新用户nick,设置其主目录为home/nick。 &#xff08;1&#xff09;添加新用户&#xff1a; sudo useradd -m 用户名 sudo passwd 新用户名 &#xff08;2&#xff09;给新用户可以执行的root权限 sudo vi /etc/sudoers #User privilege specification roo…

Spring Security实战(一)——基于内存和数据库模型的认证与授权

目录 简介 一、初识Spring Security&#xff08;入门案例&#xff09; &#xff08;1&#xff09;新建project &#xff08;2&#xff09;选择依赖 &#xff08;3&#xff09;编写一个 HelloController &#xff08;4&#xff09;启动项目&#xff0c;访问localhost:8080…

手动清除gitlab中prometheus的数据

背景&#xff1a; gitlab服务器上&#xff0c; 磁盘经常爆满。后来通过 du -sh ./* 查出prometheus下的data占了绝大多数磁盘空间。 因此&#xff0c;准备删除prometheus的数据。 思路 由于prometheus的数据占用的空间较大&#xff0c;因此在实际使用时&#xff0c;可以关闭…

【 Spring MVC 核心功能(一) - 使用注解实现 URL 路由映射】

文章目录引言一、RequestMapping 注解介绍1.1 RequestMapping 是 post 还是 get 请求&#xff1f;1.2 RequestMapping 指定一种请求方式二、GetMapping三、PostMapping四、总结引言 前面我们讲到&#xff0c;学习 Spring MVC 需要掌握三个核心功能即连接&#xff0c;获取参数&…

avi文件怎么转成mp4视频,3种方法快速学

avi文件怎么转成mp4视频&#xff1f;前面小编给大家讲了mov格式和webm格式&#xff0c;以及如何将mov和webm格式转换成mp4格式。今天小编给大家说一说另外一种视频格式&#xff0c;就是avi&#xff0c;AVI英文全称为Audio Video Interleaved&#xff0c;即音频视频交错格式&…

SpringBoot中对Bean的处理方法以及第三方Bean处理的方式

我们可以通过Spring当中提供的注解Component以及它的三个衍生注解&#xff08;Controller、Service、Repository&#xff09;来声明IOC容器中的bean对象&#xff0c;为应用程序注入运行时所需要依赖的bean对象&#xff0c;也就是依赖注入DI。 关于IOC容器中Bean的其他使用细节…

矿泉水为什么会溴酸盐超标

矿泉水为什么会溴酸盐超标&#xff1f; 水生产企业多使用臭氧消毒&#xff0c;不过&#xff0c;水生产企业不存在水运输路途遥远的问题&#xff0c;因此可以使用臭氧消毒。同时&#xff0c;也是因为臭氧在消毒后会直接变成氧气&#xff0c;所以不会有使用氯消毒后的那种味道&a…

give_you_flag(GIF原理、二维码定位符)

下载附件是一个GIF 看到最后你会发现它突然漏了一个二维码出来 我们将这个GIF分解成图片&#xff08;动图就是由多张静态图片组合而成&#xff0c;按照一定的顺序和时间播放的&#xff09; https://tu.sioe.cn/gj/fenjie/ 提取出里面包含二维码的那张 但是我们发现这里有一个…

word2vec原理

1.背景 2013年&#xff0c;Google开源了一款用于词向量计算的工具—word2vec&#xff0c;引起了工业界和学术界的关注。首先&#xff0c;word2vec可以在百万数量级的词典和上亿的数据集上进行高效地训练&#xff1b;其次&#xff0c;该工具得到的训练结果——词向量(word embed…

GDPU C语言 天码行空7

1. 数组最大值交换 ⭐ 1e9&#xff1a;10的9次方 #include<stdio.h>int main() {int n, i,idx 0;//idx 记录第一个出现的最大值下标scanf("%d", &n);double a[30];double max -1e9;// 1e9 表示10的9次方&#xff0c;十亿&#xff0c;int 的最大范围级别…

使用RT-Thread Studio搭配STM32CubeMX新建RT-Thread项目

STM32CubeMX下载 RT-Thread Studio下载 安装好RT-Thread Studio后&#xff0c;先打开RT-Thread SDK管理器确认有没有自己MCU需要的SDK包&#xff0c;直接安装好之后里面是有STM32F1系列的SDK包&#xff0c;其他的需要自己安装。 之后点击文件→新建→RT-Thread项目&#xff0…

C++ 实现 matlab 的 zp2tf 函数

文章目录1. matlab 的 zp2tf 函数的作用2. matlab 的 zp2tf 函数的使用方法3. C实现3.1 complex.h 文件3.2 zp2tf.h 文件4. 测试结果4.1 测试文件4.2 测试结果1. matlab 的 zp2tf 函数的作用 作用是将极点形式的 H(s) 函数的分母展开 2. matlab 的 zp2tf 函数的使用方法 [z,…

ICASSP2023 | 基于多任务学习的保留背景音的语音转换

在影视、有声书内容中&#xff0c;背景音是一种表现丰富的艺术形式。语音转换&#xff08;Voice Conversion&#xff09;如能将源说话人语音转换成目标说话人语音的同时&#xff0c;保留源语音中的背景音&#xff0c;将会提供更沉浸的语音转换体验。之前的语音转换研究主要关注…

低代码平台很赞,用2个小时,搭出1套应用

最近低代码很火&#xff0c;到处都是低代码的尝试贴&#xff0c;笔者今天也决定深入体验一下&#xff0c;感受它的便捷程度。 在案例开始之前&#xff0c;我们先来聊聊概念。 一、低代码 低代码实质上并不是一个新颖的话题&#xff0c;也不是最近才有的技术突破和创新&#xf…

Python--异常处理机制

Python异常处理机制 1、什么是异常处理&#xff1a; 程序运行时常会碰到一些错误&#xff0c;例如除数为 0、年龄为负数、数组下标越界等&#xff0c;这些错误如果不能发现并加以处理&#xff0c;很可能会导致程序崩溃。 可以简单的理解异常处理机制&#xff0c;就是在程序运…

Nginx生产环境配置、elasticsearch生产环境配置、rocketmq生产环境配置 (史上最全)

Nginx实现10万并发 在优化内核时&#xff0c;可以做的事情很多&#xff0c;不过&#xff0c;我们通常会根据业务特点来进行调整&#xff0c;当Nginx作为静态web内容服务器、反向代理或者提供压缩服务器的服务器时&#xff0c;期内核参数的调整都是不同的&#xff0c; 概述&am…

计算机组成原理——第五章中央处理器

半生风雨半生伤&#xff0c;半醉半醒半心凉 文章目录前言5.1 CPU的功能和基本结构5.2 指令周期的数据流5.3.1 单总线结构5.3.2 专用通路结构前言 之前我们就说过CPU主要包括两个部分&#xff0c;运算器和控制器&#xff0c;运算器主要是实现算数运算.逻辑运算&#xff0c; 运算…

React 搜索时遇到的坑

一、业务场景&#xff1a; 最近在优化React的天枢项目里面&#xff0c;搜索时遇到了一些问题。为了大家后面遇到和我一样的问题&#xff0c;给大家分享一下 二、问题描述&#xff1a; 1.点击搜索按钮&#xff0c;报以下错误。 TypeError: Converting circular structure to J…

全景丨0基础学习VR全景制作,平台篇:如何从素材库发布VR漫游

大家好欢迎观看蛙色平台使用教程 大家可以将创建作品理解成搭建房子&#xff0c;建房子需要基础的砖块、木头、钉子等原材料&#xff0c;房子成品是多种原材料的有机组合&#xff0c;而蛙色VR平台在创建作品前&#xff0c;也需要先准备对应的基础原材料。当前蛙色VR素材上传类型…

C++实现前缀树

文章目录1. 什么是前缀树2. 前缀树的实现2.1 前缀树的基本结构2.2 插入2.3 word出现了几次2.3 word作为前缀出现几次2.4 删除1. 什么是前缀树 假设这里有一个字符串数组&#xff0c;和一个树的根结点&#xff1a; 这个结点的pass意思是&#xff1a;有几个字符通过了这个结点。…