国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

左手Python 右手R —— 最大公約數(shù)和最小公倍數(shù)

這篇具有很好參考價(jià)值的文章主要介紹了左手Python 右手R —— 最大公約數(shù)和最小公倍數(shù)。希望對(duì)大家有所幫助。如果存在錯(cuò)誤或未考慮完全的地方,請(qǐng)大家不吝賜教,您也可以點(diǎn)擊"舉報(bào)違法"按鈕提交疑問。


前言

??此專欄為python與R語言對(duì)比學(xué)習(xí)的文章;以通俗易懂的小實(shí)驗(yàn),帶領(lǐng)大家深入淺出的理解兩種語言的基本語法,并用以實(shí)際場景!感謝大家的關(guān)注,希望對(duì)大家有所幫助。
??“博觀而約取,厚積而薄發(fā)!”謹(jǐn)以此言,望諸君共勉

??本文針對(duì)數(shù)學(xué)問題“最大公約數(shù)、最小公倍數(shù)”進(jìn)行講解。具體的項(xiàng)目介紹見下文。


1、 最大公約數(shù)

1.1 約數(shù)

??在講述最大公約數(shù)之前我們先來認(rèn)識(shí)一下什么是約數(shù)。約數(shù)(又稱因數(shù)),整數(shù)a除以整數(shù)b(b≠0) 除得的商正好是整數(shù)而沒有余數(shù),我們就說a能被b整除,或b能整除a。a稱為b的倍數(shù),b稱為a的約數(shù)。因此不能孤立地說某個(gè)整數(shù)是約數(shù)。
??如: 4 = 1 ? 4 = 2 ? 2 【則稱 4 、 2 、 1 是 4 的約數(shù)】 4=1*4=2*2 【則稱4、2、1是4的約數(shù)】 4=1?4=2?2【則稱4、2、14的約數(shù)】
???? 6 = 1 ? 6 = 2 ? 3 【則稱 6 、 3 、 2 、 1 是 6 的約數(shù)】 6=1*6=2*3 【則稱6、3、2、1是6的約數(shù)】 6=1?6=2?3【則稱6、3、2、16的約數(shù)】
???? . . . . . . . . . . . . . . . . . . .................. ..................
????注:一個(gè)數(shù)的約數(shù)必然包括1及其本身。

1.2 最大公約數(shù)

??如上展示的例子中,如果一個(gè)數(shù)c既是數(shù)a的約數(shù),又是數(shù)b的約數(shù),那么c叫做a與b的公約數(shù)。兩個(gè)數(shù)的公因數(shù)中最大的一個(gè),叫做這兩個(gè)數(shù)的最大公約數(shù)。
??如: 在上面的例子中, 4 和 6 的公約數(shù)有: 1 、 2 。 在上面的例子中,4和6的公約數(shù)有:1、2。 在上面的例子中,46的公約數(shù)有:1、2。
??????????? ? ? 4 和 6 的最大公約數(shù)是 2 。 4和6的最大公約數(shù)是2。 46的最大公約數(shù)是2

1.3 求解方法

??在知道約數(shù)及最大公約數(shù)的基本概念之后,我們進(jìn)行求解,找出任意兩個(gè)數(shù)的最大公約數(shù):(此處展示常用的兩種解法)
例: 求解 12 和 18 的最大公約數(shù)。

??枚舉法: 12 的約數(shù)有 12 、 6 、 4 、 3 、 2 、 1 12的約數(shù)有 12、6、4、3、2、1 12的約數(shù)有12、64、3、2、1
?????? 18 的約數(shù)有 18 、 9 、 6 、 3 、 2 、 1 18的約數(shù)有 18、9、6、3、2、1 18的約數(shù)有189、63、21
?????? 所以 18 和 12 的最大約數(shù)是 6 所以18和12的最大約數(shù)是6 所以1812的最大約數(shù)是6

??短除法: 短除符號(hào)就像一個(gè)倒過來的除號(hào),短除法就是先寫出要求最大公因數(shù)的兩個(gè)數(shù)A、B,再畫一個(gè)短除號(hào),接著在原本寫除數(shù)的位置寫兩個(gè)數(shù)公有的質(zhì)因數(shù)Z(通常從最小的質(zhì)數(shù)開始),然后在短除號(hào)的下方寫出這兩個(gè)數(shù)被Z整除的商a,b,對(duì)a,b重復(fù)以上步驟,以此類推,直到最后的商互質(zhì)為止,再把所有的除數(shù)相乘,其積即為A,B的最大公因數(shù)。
左手Python 右手R —— 最大公約數(shù)和最小公倍數(shù)
??程序求解: 采取短除法的逆向思維,短除法從最小的公質(zhì)數(shù)開始,此法能快速找到除了1的最小公約數(shù),反其道而行,如若我們重較小數(shù)開始遞減,滿足能同時(shí)被 x y 整除;則該數(shù)就是最大公約數(shù)。
左手Python 右手R —— 最大公約數(shù)和最小公倍數(shù)


2、 最小公倍數(shù)

2.1 倍數(shù)

??一個(gè)整數(shù)能夠被另一個(gè)整數(shù)整除,那么這個(gè)整數(shù)就是另一整數(shù)的倍數(shù)。與約數(shù)不同的是,一個(gè)數(shù)可以有無數(shù)個(gè)倍數(shù),而約數(shù)是有限的,因此無法通過枚舉法完全展示出一個(gè)數(shù)的倍數(shù)。
??如: 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 最小公倍數(shù)

??兩個(gè)或多個(gè)整數(shù)公有的倍數(shù)叫做它們的公倍數(shù)。倍數(shù)可以有無數(shù)多個(gè),也可以無限大,因此多個(gè)整數(shù)之間只有最小公倍數(shù)。
??如: 12 的倍數(shù)有 0 、 12 、 24 、 36 、 48 、 60 、 72...... 12的倍數(shù)有 0、12、24、36、48、60、72...... 12的倍數(shù)有0、12、2436、4860、72......
???? 18 的倍數(shù)有 0 、 18 、 36 、 54 、 72 、 90 、 108...... 18的倍數(shù)有 0、18、36、54、72、90、108...... 18的倍數(shù)有0、18、36、54、72、90108......
???? 則稱 12 和 18 的最小公倍數(shù)為 36 則稱 12 和18的最小公倍數(shù)為36 則稱1218的最小公倍數(shù)為36

2.3 求解方法

??在知道倍數(shù)及最小公倍數(shù)的基本概念之后,我們進(jìn)行求解,找出任意兩個(gè)數(shù)的最小公倍數(shù):(此處展示常用的兩種解法)任然是求12和18的最小公倍數(shù)。
??短除法: 與上面一樣的算法,只是在最后的結(jié)果時(shí)把所有的除數(shù)和余數(shù)相乘。
左手Python 右手R —— 最大公約數(shù)和最小公倍數(shù)
??公式法: 所謂公式法(最大公約數(shù)與最小公倍數(shù)關(guān)系)就是對(duì)于任意兩個(gè)自然數(shù) a 、 b a、b ab,只要先求出這兩個(gè)數(shù)的最大公約數(shù)后,利用公式 [ a , b ] ? ( a , b ) = a ? b [a,b] *(a,b) =a*b [a,b]?(ab)=a?b即可求出最小公倍數(shù) [ a , b ] = a ? b / ( a , b ) [a,b]=a*b/(a,b) [a,b]=a?b/(ab) ,也即是兩個(gè)數(shù)的最小公倍數(shù)等于這兩個(gè)數(shù)的乘積除以這兩個(gè)數(shù)的最大公約數(shù)。這里可以取兩個(gè)質(zhì)數(shù)進(jìn)行驗(yàn)證
3 和 5 的最大公約數(shù)為 1 則有最小公倍數(shù) = 3 ? 5 / 1 = 15 3和5的最大公約數(shù)為1 則有最小公倍數(shù)=3*5/1=15 35的最大公約數(shù)為1則有最小公倍數(shù)=3?5/1=15


3、程序?qū)崿F(xiàn)

程序僅展示公式法求最小公倍數(shù)

3.1 python 代碼實(shí)現(xiàn)

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

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

# 從兩個(gè)數(shù)中較小的數(shù)開始做遞減循環(huán)
for fac in range(x,0,-1):
    if x % fac == 0 and y % fac == 0 :
        print('{}和{}的最大公約數(shù)是:{}'.format(x,y,fac))
        print('{}和{}的最小公倍數(shù)是:{}'.format(x,y,x*y//fac))
        break

左手Python 右手R —— 最大公約數(shù)和最小公倍數(shù)

3.2 R語言代碼實(shí)現(xiàn)

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("最大公約數(shù)為:",i)
      cat("\n最小公倍數(shù)為:",x*y%/%i)
      break
    }
  }
}
test_5 <- function(){
  print("請(qǐng)輸入需要計(jì)算的數(shù)值")
  math_diy()
}
test_5()

左手Python 右手R —— 最大公約數(shù)和最小公倍數(shù)

小結(jié)

??本次仍然是對(duì)條件、循環(huán)、及自定函數(shù)的混合使用;
??R語言看起來比較復(fù)雜,無非是都嵌套在了自定函數(shù)里,如有問題,可以私信哦!
??任何問題只要了解了本質(zhì),都能通過代碼實(shí)現(xiàn);大家可以自己練習(xí)一下。

??這是左手Python右手R系列的第3片文章,希望大家能喜歡這個(gè)系列。

創(chuàng)作不易,都瀏覽到這兒了,看官可否將下面的收藏點(diǎn)贊幫忙點(diǎn)亮。

左手Python 右手R —— 最大公約數(shù)和最小公倍數(shù)文章來源地址http://www.zghlxwxcb.cn/news/detail-419905.html

到了這里,關(guān)于左手Python 右手R —— 最大公約數(shù)和最小公倍數(shù)的文章就介紹完了。如果您還想了解更多內(nèi)容,請(qǐng)?jiān)谟疑辖撬阉鱐OY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點(diǎn)僅代表作者本人,不代表本站立場。本站僅提供信息存儲(chǔ)空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請(qǐng)注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實(shí)不符,請(qǐng)點(diǎn)擊違法舉報(bào)進(jìn)行投訴反饋,一經(jīng)查實(shí),立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費(fèi)用

相關(guān)文章

  • 【C語言】求最大公約數(shù)和最小公倍數(shù)

    【C語言】求最大公約數(shù)和最小公倍數(shù)

    方法一:利用 定義法 求最大公因數(shù)和最小公倍數(shù) 方法二:最小公倍數(shù)求法同上, 最大公約數(shù)方法不同 方法一方法二的結(jié)果示例如下 ? 方法三:利用 輾轉(zhuǎn)相除法 求最大公約數(shù)和最小公倍數(shù) 法(1)結(jié)果示例如下: ?法(2)示例結(jié)果如下: ?以上就是用C語言循環(huán)和循環(huán)之前的

    2024年02月07日
    瀏覽(94)
  • P1029 最大公約數(shù)和最小公倍數(shù)問題

    3 2 1 上題目鏈接: P1029 [NOIP2001 普及組] 最大公約數(shù)和最小公倍數(shù)問題 本小蒟蒻的原始思路就是枚舉所有范圍內(nèi)的數(shù),分別求出他們的最大公約數(shù)和最小公倍數(shù),再看是否滿足題意。 于是就有了以下一言難盡的東西(;′⌒`)↓ 皇天不負(fù)有心人,收到了2個(gè)TLE,其他全WA 自我反

    2024年02月19日
    瀏覽(25)
  • C++求最大公約數(shù)和最小公倍數(shù)的方法

    每次遇到最大公約數(shù)和最小公倍數(shù)時(shí)總是忘記,這里總結(jié)了兩種求最大公約數(shù)和最小公倍數(shù)的方法。 歐幾里得算法是求解兩個(gè)數(shù)的最大公約數(shù)的一種常用方法。該算法基于以下原理:兩個(gè)整數(shù)的最大公約數(shù)等于其中較小數(shù)和兩數(shù)的余數(shù)之間的最大公約數(shù)。可以通過遞歸調(diào)用該

    2024年02月15日
    瀏覽(25)
  • 【C語言】兩個(gè)整數(shù)最大公約數(shù)和最小公倍數(shù)

    輸入兩個(gè)整數(shù),求這兩個(gè)數(shù)的最大公約數(shù)和最小公倍數(shù)。 第一種求法(輾轉(zhuǎn)相除法)這個(gè)方法代碼較潔簡,我也比較推薦就是剛開始有點(diǎn)比較難了解。 首先,來看看怎么求最大公約數(shù),求最大公約數(shù)需要用到 歐幾里得算法 ,也稱為輾轉(zhuǎn)相除法。算法就是用兩數(shù)中較大的數(shù)

    2024年02月04日
    瀏覽(26)
  • 求其最大公約數(shù)和最小公倍數(shù),一行代碼完成

    題目:輸入兩個(gè)正整數(shù) m 和 n,求其最大公約數(shù)和最小公倍數(shù)。 求出最大公約數(shù)就行,最小公倍數(shù)用m*n除以最大公約數(shù)就行

    2024年02月05日
    瀏覽(27)
  • 【c語言】—求最大公約數(shù)和最小公倍數(shù)多種方法

    目錄 一.求最大公約數(shù) 1.枚舉法求最大公約數(shù) 2.輾轉(zhuǎn)相除法 二.求最小公倍數(shù) 1.枚舉法求最小公倍數(shù) 2.簡易法 3.公式法 思路:先求兩個(gè)數(shù)中的最小值,最大公約數(shù)不可能大于兩個(gè)數(shù)的最小數(shù) 比如6和18,最大公約數(shù)就是6 再如3和9,最大公約數(shù)就是3 然后再從1開始循環(huán)遍歷到最小

    2024年02月08日
    瀏覽(22)
  • 【C語言】一篇博客帶你弄懂最大公約數(shù)和最小公倍數(shù)

    【C語言】一篇博客帶你弄懂最大公約數(shù)和最小公倍數(shù)

    我們在C語言的學(xué)習(xí)中,經(jīng)常會(huì)遇到這樣一些數(shù)學(xué)題目,良好掌握這些題目有利于我們理解和學(xué)習(xí)C語言,話不多說,直接進(jìn)入主題 最大公約數(shù): 首先我們舉個(gè)例子,比如12 和16,12的約數(shù)有(1,2 ,3,4,6,12),16的約數(shù)有(1,2,4,8,16)公約數(shù)就是兩個(gè)數(shù)共同的約數(shù),(1,2,4)而公約數(shù)

    2024年02月04日
    瀏覽(18)
  • 輸入兩個(gè)正整數(shù),求這兩個(gè)正整數(shù)的最大公約數(shù)和最小公倍數(shù)。

    輸入兩個(gè)正整數(shù),求這兩個(gè)正整數(shù)的最大公約數(shù)和最小公倍數(shù)。

    一、輸入兩個(gè)正整數(shù),求這兩個(gè)正整數(shù)的最大公約數(shù)和最小公倍數(shù)。 ? ? ? ? 最大公約數(shù):1、這個(gè)數(shù)同時(shí)能被兩個(gè)整數(shù)整除,余數(shù)為0 就是公約數(shù) ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? 2、只要在公約數(shù)中取最大值即可 ? ? ? ? 最小公倍數(shù):1、這個(gè)數(shù)能同時(shí)整除兩個(gè)正整數(shù) ? ?

    2024年02月06日
    瀏覽(22)
  • C語言——輸入兩個(gè)正整數(shù)m和n,求其最大公約數(shù)和最小公倍數(shù)

    C語言——輸入兩個(gè)正整數(shù)m和n,求其最大公約數(shù)和最小公倍數(shù)

    目錄 1.最大公約數(shù)求法 1.1輾轉(zhuǎn)相除法 1.2相減法 2.最小公倍數(shù)求法 3.代碼實(shí)現(xiàn) 4.結(jié)果展示 1.1輾轉(zhuǎn)相除法 設(shè)有兩整數(shù)a和b: a%b得余數(shù)c 若c==0,則b即為兩數(shù)的最大公約數(shù) 若c!=0,則a=b,b=c,再回去執(zhí)行第一步。 例如:求27和15的最大公約數(shù)過程為: 27÷15 余12 15÷12 余3 12÷3 余0 因

    2024年02月01日
    瀏覽(14)
  • C語言——輸入兩個(gè)正整數(shù) m 和 n。求其最大公約數(shù)和最小公倍數(shù)。

    1、首先,程序通過printf函數(shù)提示用戶輸入兩個(gè)正整數(shù)m和n,然后使用scanf函數(shù)接收用戶的輸入并將值分別存儲(chǔ)到變量m和n中。 2、接下來,程序進(jìn)入一個(gè)for循環(huán),從1開始遍歷直至i等于較小的數(shù)(m或n),檢查當(dāng)前數(shù)值i是否能同時(shí)整除m和n。如果i既能被m整除又能被n整除(即滿足

    2024年02月03日
    瀏覽(21)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請(qǐng)作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包